नियंत्रण प्रवाह विश्लेषण: Difference between revisions
No edit summary |
No edit summary |
||
Line 1: | Line 1: | ||
{{Short description|Compiler technique}} | {{Short description|Compiler technique}} | ||
[[कंप्यूटर विज्ञान]] में, | [[कंप्यूटर विज्ञान]] में, '''कंट्रोल-फ्लो एनालिसिस''' (सीएफए) एक प्रोग्राम के कंट्रोल फ्लो को निर्धारित करने के लिए एक स्थैतिक-कोड-एनालिसिस तकनीक है। कंट्रोल फ्लो को [[नियंत्रण-प्रवाह ग्राफ|कंट्रोल-फ्लो ग्राफ]] (सीएफजी) के रूप में व्यक्त किया जाता है। [[कार्यात्मक प्रोग्रामिंग भाषा|फंक्शनल प्रोग्रामिंग]] [[लैंगुएजेस]] और [[ऑब्जेक्ट-ओरिएंटेड प्रोग्रामिंग भाषा|ऑब्जेक्ट-ओरिएंटेड प्रोग्रामिंग]] लैंगुएजेस दोनों के लिए, सीएफए शब्द, और ''के''-सीएफए जैसे विस्तार, स्पेसिफिक एल्गोरिदम को संदर्भित करते हैं जो कंट्रोल फ्लो की गणना करते हैं। | ||
कई [[अनिवार्य प्रोग्रामिंग भाषा]] | कई [[अनिवार्य प्रोग्रामिंग भाषा|इम्परेटिव प्रोग्रामिंग]] [[लैंगुएजेस]] के लिए, प्रोग्राम का कंट्रोल फ्लो प्रोग्राम के स्रोत कोड में स्पष्ट होता है। परिणामस्वरूप, [[अंतरप्रक्रियात्मक विश्लेषण|अंतरप्रक्रियात्मक एनालिसिस]] कंट्रोल-फ्लो एनालिसिस सामान्यतः [[उच्च-क्रम प्रोग्रामिंग भाषा|हायर आर्डर प्रोग्रामिंग लैंग्वेज]] में लिखे गए कंप्यूटर प्रोग्राम में फ़ंक्शन या विधि कॉल के रिसीवर को निर्धारित करने के लिए एक [[स्थैतिक विश्लेषण|स्थैतिक एनालिसिस]] तकनीक को संदर्भित करता है।{{dubious|date=July 2014}} उदाहरण के लिए, स्कीम (प्रोग्रामिंग लैंग्वेज) जैसे हायर आर्डर वाले फ़ंक्शन वाली प्रोग्रामिंग लैंग्वेज में, फ़ंक्शन कॉल का टारगेट स्पष्ट नहीं हो सकता है: आइसोलेटेड एक्सप्रेशन में, | ||
<syntaxhighlight lang="scheme"> | <syntaxhighlight lang="scheme"> | ||
(lambda (f) (f x)) | (lambda (f) (f x)) | ||
</syntaxhighlight> | </syntaxhighlight> | ||
यह स्पष्ट नहीं है कि | यह स्पष्ट नहीं है कि <code>f</code> किस प्रक्रिया का उल्लेख कर सकता है। कंट्रोल-फ्लो एनालिसिस को इस बात पर विचार करना चाहिए कि इस अभिव्यक्ति को कहां लागू किया जा सकता है और संभावित टारगेटों को निर्धारित करने के लिए इसे क्या तर्क प्राप्त हो सकते हैं। | ||
कंट्रोल-फ्लो एनालिसिस के लिए [[कंस्ट्रेंट सॉल्विंग|अब्सट्रैकट इंटरप्रिटेशन]], [[कंस्ट्रेंट सॉल्विंग]] और [[टाइप सिस्टम]] जैसी तकनीकों का उपयोग किया जा सकता है।<ref>{{cite book |author-first1=Flemming |author-last1=Nielson |author-first2=Hanne Riis |author-last2=Nielson |author-first3=Chris |author-last3=Hankin |title=कार्यक्रम विश्लेषण के सिद्धांत|publisher=[[Springer Science+Business Media]] |date=2005}}</ref> | |||
==यह भी देखें== | ==यह भी देखें== | ||
* [[नियंत्रण-प्रवाह आरेख]] (सीएफडी) | * [[नियंत्रण-प्रवाह आरेख|कंट्रोल-फ्लो आरेख]] (सीएफडी) | ||
* [[डेटा-प्रवाह विश्लेषण]] | * [[डेटा-प्रवाह विश्लेषण|डेटा-फ्लो एनालिसिस]] | ||
* [[कार्टेशियन उत्पाद एल्गोरिथ्म]] | * [[कार्टेशियन उत्पाद एल्गोरिथ्म]] | ||
* [[सूचक विश्लेषण]] | * [[सूचक विश्लेषण|सूचक एनालिसिस]] | ||
==संदर्भ== | ==संदर्भ== |
Revision as of 09:38, 7 August 2023
कंप्यूटर विज्ञान में, कंट्रोल-फ्लो एनालिसिस (सीएफए) एक प्रोग्राम के कंट्रोल फ्लो को निर्धारित करने के लिए एक स्थैतिक-कोड-एनालिसिस तकनीक है। कंट्रोल फ्लो को कंट्रोल-फ्लो ग्राफ (सीएफजी) के रूप में व्यक्त किया जाता है। फंक्शनल प्रोग्रामिंग लैंगुएजेस और ऑब्जेक्ट-ओरिएंटेड प्रोग्रामिंग लैंगुएजेस दोनों के लिए, सीएफए शब्द, और के-सीएफए जैसे विस्तार, स्पेसिफिक एल्गोरिदम को संदर्भित करते हैं जो कंट्रोल फ्लो की गणना करते हैं।
कई इम्परेटिव प्रोग्रामिंग लैंगुएजेस के लिए, प्रोग्राम का कंट्रोल फ्लो प्रोग्राम के स्रोत कोड में स्पष्ट होता है। परिणामस्वरूप, अंतरप्रक्रियात्मक एनालिसिस कंट्रोल-फ्लो एनालिसिस सामान्यतः हायर आर्डर प्रोग्रामिंग लैंग्वेज में लिखे गए कंप्यूटर प्रोग्राम में फ़ंक्शन या विधि कॉल के रिसीवर को निर्धारित करने के लिए एक स्थैतिक एनालिसिस तकनीक को संदर्भित करता है।[dubious ] उदाहरण के लिए, स्कीम (प्रोग्रामिंग लैंग्वेज) जैसे हायर आर्डर वाले फ़ंक्शन वाली प्रोग्रामिंग लैंग्वेज में, फ़ंक्शन कॉल का टारगेट स्पष्ट नहीं हो सकता है: आइसोलेटेड एक्सप्रेशन में,
(lambda (f) (f x))
यह स्पष्ट नहीं है कि f
किस प्रक्रिया का उल्लेख कर सकता है। कंट्रोल-फ्लो एनालिसिस को इस बात पर विचार करना चाहिए कि इस अभिव्यक्ति को कहां लागू किया जा सकता है और संभावित टारगेटों को निर्धारित करने के लिए इसे क्या तर्क प्राप्त हो सकते हैं।
कंट्रोल-फ्लो एनालिसिस के लिए अब्सट्रैकट इंटरप्रिटेशन, कंस्ट्रेंट सॉल्विंग और टाइप सिस्टम जैसी तकनीकों का उपयोग किया जा सकता है।[1]
यह भी देखें
संदर्भ
- ↑ Nielson, Flemming; Nielson, Hanne Riis; Hankin, Chris (2005). कार्यक्रम विश्लेषण के सिद्धांत. Springer Science+Business Media.