ब्रांच (कंप्यूटर साइंस)

एक शाखा एक कंप्यूटर प्रोग्राम में एक निर्देश है जो एक कंप्यूटर को एक अलग निर्देश अनुक्रम निष्पादित करना शुरू कर सकता है और इस प्रकार निर्देशों को क्रियान्वित करने के अपने डिफ़ॉल्ट व्यवहार से विचलित हो सकता है। ब्रांच (या ब्रांचिंग, ब्रांच्ड) ब्रांच इंस्ट्रक्शन को निष्पादित करने के परिणामस्वरूप निष्पादन को एक अलग निर्देश अनुक्रम में स्विच करने के कार्य को भी संदर्भित कर सकता है। शाखा निर्देशों का उपयोग प्रोग्राम लूप और सशर्त में नियंत्रण प्रवाह को लागू करने के लिए किया जाता है (अर्थात, निर्देशों के एक विशेष अनुक्रम को केवल तभी निष्पादित किया जाता है जब कुछ शर्तें पूरी होती हैं)।

एक शाखा निर्देश या तो एक बिना शर्त शाखा हो सकता है, जिसके परिणामस्वरूप हमेशा शाखाकरण होता है, या एक सशर्त शाखा हो सकती है, जो कुछ स्थितियों के आधार पर शाखाकरण का कारण हो भी सकती है और नहीं भी। इसके अलावा, यह नए निर्देश अनुक्रम (लक्षित पता) के पते को कैसे निर्दिष्ट करता है, इसके आधार पर, एक शाखा निर्देश को आम तौर पर 'प्रत्यक्ष', 'अप्रत्यक्ष' या 'सापेक्ष' के रूप में वर्गीकृत किया जाता है, जिसका अर्थ है कि निर्देश में शामिल है लक्ष्य पता, या यह निर्दिष्ट करता है कि लक्ष्य पता कहाँ पाया जाना है (उदाहरण के लिए, एक रजिस्टर या मेमोरी स्थान), या यह वर्तमान और लक्ष्य पते के बीच अंतर को निर्दिष्ट करता है।

कार्यान्वयन
शाखा निर्देश सीपीयू के कार्यक्रम गणक (या पीसी) (या इंटेल माइक्रोप्रोसेसरों पर निर्देश सूचक) की सामग्री को बदल सकते हैं। पीसी अगले मशीन निर्देश के स्मृति पते को लाने और निष्पादित करने के लिए बनाए रखता है। इसलिए, एक शाखा, यदि निष्पादित की जाती है, तो प्रोग्रामर द्वारा नियोजित एल्गोरिथम के अनुसार प्रोग्राम लॉजिक को बदलते हुए, सीपीयू को एक नए मेमोरी एड्रेस से कोड निष्पादित करने का कारण बनता है।

एक प्रकार की मशीन स्तरीय शाखा जंप इंस्ट्रक्शन है। हो सकता है या न हो कि पीसी को कुछ नए, अलग मूल्य के साथ लोड या संशोधित किया जा रहा हो, जो सामान्य रूप से होता (निम्नलिखित, अगले निर्देश को इंगित करने के लिए वर्तमान निर्देश से आगे बढ़ाया जा रहा है)। छलांग में आमतौर पर बिना शर्त और सशर्त रूप होते हैं जहां बाद वाले को कुछ शर्तों के आधार पर लिया या नहीं लिया (पीसी संशोधित किया गया है या नहीं) लिया जा सकता है।

दूसरी प्रकार की मशीन स्तर शाखा कॉल निर्देश है जिसका उपयोग सबरूटीन्स को लागू करने के लिए किया जाता है। जंप निर्देशों की तरह, कॉल स्थिति कोड के अनुसार पीसी को संशोधित या संशोधित नहीं कर सकते हैं, हालांकि, अतिरिक्त वापसी पता स्मृति में एक सुरक्षित स्थान में सहेजा जाता है (आमतौर पर स्मृति निवासी डेटा संरचना में जिसे स्टैक कहा जाता है (अमूर्त डेटा प्रकार)#हार्डवेयर स्टैक ). सबरूटीन के पूरा होने पर, यह वापसी पता पीसी पर बहाल हो जाता है, और इसलिए प्रोग्राम निष्पादन कॉल निर्देश के बाद निर्देश के साथ फिर से शुरू होता है।

तीसरी प्रकार की मशीन स्तरीय शाखा वापसी निर्देश है। यह स्टैक से रिटर्न एड्रेस को पॉप करता है और इसे पीसी रजिस्टर में लोड करता है, इस प्रकार कॉलिंग रूटीन पर नियंत्रण लौटाता है। वापसी के निर्देश भी सशर्त रूप से निष्पादित किए जा सकते हैं। यह वर्णन साधारण अभ्यास से संबंधित है; हालांकि, मशीन प्रोग्रामर के पास स्टैक पर रिटर्न एड्रेस में हेरफेर करने की काफी शक्तियां होती हैं, और इसलिए किसी भी संख्या में विभिन्न तरीकों से प्रोग्राम निष्पादन को पुनर्निर्देशित करता है।

प्रोसेसर के आधार पर, जंप और कॉल निर्देश पीसी रजिस्टर की सामग्री को विभिन्न तरीकों से बदल सकते हैं। एक निरपेक्ष पता लोड किया जा सकता है, या पीसी की वर्तमान सामग्री में कुछ मूल्य (या विस्थापन) जोड़ा जा सकता है या इसके वर्तमान मूल्य से घटाया जा सकता है, जिससे गंतव्य पता कार्यक्रम में वर्तमान स्थान के सापेक्ष हो जाता है। विस्थापन मूल्य का स्रोत भिन्न हो सकता है, जैसे निर्देश के भीतर एम्बेडेड तत्काल मूल्य, या प्रोसेसर रजिस्टर या मेमोरी स्थान की सामग्री, या किसी स्थान की सामग्री को इंडेक्स वैल्यू में जोड़ा जाता है।

उच्च स्तरीय प्रोग्रामिंग भाषाओं में कार्यक्रमों का जिक्र करते समय 'शाखा' शब्द का भी उपयोग किया जा सकता है। इन शाखाओं में आमतौर पर विभिन्न रूपों के सशर्त (प्रोग्रामिंग) का रूप लेते हैं जो निर्देश अनुक्रम को समाहित करते हैं जो शर्तों के संतुष्ट होने पर निष्पादित होंगे। बिना शर्त शाखा निर्देश जैसे GOTO का उपयोग बिना शर्त के एक अलग निर्देश अनुक्रम में जाने के लिए किया जाता है। यदि एल्गोरिथ्म को एक सशर्त शाखा की आवश्यकता होती है, तो GOTO (या GOSUB सबरूटीन कॉल) एक सशर्त (कंप्यूटर प्रोग्रामिंग)#If–then(–else)|IF-THEN कथन से पहले होता है जो शर्तों को निर्दिष्ट करता है। सभी उच्च स्तरीय भाषाएं एल्गोरिदम का समर्थन करती हैं जो नियंत्रण प्रवाह # लूप्स के रूप में कोड का पुन: उपयोग कर सकती हैं, एक नियंत्रण संरचना जो निर्देशों के अनुक्रम को दोहराती है जब तक कि कुछ शर्त संतुष्ट न हो जाए जिससे लूप समाप्त हो जाए। लूप शाखा निर्देश के रूप में भी योग्य हैं। मशीन स्तर पर, लूप्स को सामान्य सशर्त छलांग के रूप में लागू किया जाता है जो निष्पादन को दोहराए जाने वाले कोड पर पुनर्निर्देशित करता है।

फ़्लैग रजिस्टर वाले CPU में, पहले वाला निर्देश फ़्लैग रजिस्टर में एक शर्त सेट करता है। पहले का निर्देश अंकगणित तर्क इकाई | अंकगणित या तर्क निर्देश हो सकता है। यह अक्सर शाखा के करीब होता है, हालांकि जरूरी नहीं कि शाखा से पहले 'तुरंत' निर्देश हो। संग्रहीत स्थिति का उपयोग तब एक शाखा में किया जाता है जैसे कि 'जंप इफ ओवरफ्लो-फ्लैग सेट'। यह अस्थायी जानकारी अक्सर फ़्लैग रजिस्टर में संग्रहीत होती है, लेकिन यह कहीं और भी स्थित हो सकती है। एक झंडा रेगीधीमी, सरल कंप्यूटरों में स्टर डिज़ाइन सरल है। तेज कंप्यूटरों में एक झंडा रजिस्टर गति पर अड़चन डाल सकता है, क्योंकि निर्देश जो अन्यथा समानांतर (कई निष्पादन इकाइयों में) काम कर सकते हैं, उन्हें फ्लैग बिट्स को एक विशेष क्रम में सेट करने की आवश्यकता होती है।

ऐसी मशीनें भी हैं (या विशेष निर्देश) जहां कूद निर्देश द्वारा ही स्थिति की जांच की जा सकती है, जैसे शाखा <लेबल> यदि रजिस्टर एक्स नकारात्मक। सरल कंप्यूटर डिजाइनों में, तुलना शाखाएं अधिक अंकगणित निष्पादित करती हैं और फ्लैग रजिस्टर शाखाओं की तुलना में अधिक शक्ति का उपयोग कर सकती हैं। तेज़ कंप्यूटर डिज़ाइन में तुलना शाखाएँ फ़्लैग रजिस्टर शाखाओं की तुलना में तेज़ी से चल सकती हैं, क्योंकि तुलना शाखाएँ गणना के रूप में समान CPU तंत्र का उपयोग करके अधिक समानता के साथ रजिस्टरों तक पहुँच सकती हैं।

कुछ शुरुआती और सरल सीपीयू आर्किटेक्चर, जो अभी भी माइक्रोकंट्रोलर्स में पाए जाते हैं, एक सशर्त कूद को लागू नहीं कर सकते हैं, बल्कि केवल एक सशर्त अगले निर्देश ऑपरेशन को छोड़ देते हैं। एक सशर्त कूद या कॉल इस प्रकार एक बिना शर्त कूद या कॉल निर्देश की सशर्त छोड़ने के रूप में कार्यान्वित की जाती है।

उदाहरण
कंप्यूटर आर्किटेक्चर के आधार पर, जंप इंस्ट्रक्शन के लिए सभा की भाषा स्मृति सहायक आमतौर पर शब्द जंप या शब्द शाखा का कुछ छोटा रूप होता है, अक्सर अन्य सूचनात्मक अक्षरों (या एक अतिरिक्त पैरामीटर) के साथ स्थिति का प्रतिनिधित्व करता है। कभी-कभी अन्य विवरण भी शामिल होते हैं, जैसे कि छलांग की सीमा (ऑफ़सेट आकार) या एक विशेष एड्रेसिंग मोड जिसका उपयोग वास्तविक प्रभावी ऑफ़सेट का पता लगाने के लिए किया जाना चाहिए।

यह तालिका मशीन स्तर की शाखा या कई प्रसिद्ध आर्किटेक्चर में पाए जाने वाले जंप निर्देशों को सूचीबद्ध करती है:


 * x86, PDP-11, VAX, और कुछ अन्य, कैरी-फ्लैग को सिग्नल बॉरो पर सेट करते हैं और कैरी-फ्लैग को नो बॉरो सिग्नल के लिए क्लियर करते हैं। एआरएम, 6502, पीआईसी, और कुछ अन्य, घटिया संचालन के लिए विपरीत कार्य करते हैं। कुछ निर्देशों के लिए कैरी फ़्लैग का यह उलटा कार्य किसके द्वारा चिह्नित किया गया है (*), यानी, उधार = नहीं तालिका के कुछ हिस्सों में ले जाएं, लेकिन यदि अन्यथा नोट नहीं किया गया है, तो उधार लें≡कैरी। हालाँकि, ऐडिटिव ऑपरेशंस को जारी रखने के लिए अधिकांश आर्किटेक्चर द्वारा उसी तरह से हैंडल किया जाता है।

शाखा निर्देशों के साथ प्रदर्शन समस्याएं
उच्च प्रदर्शन प्राप्त करने के लिए, आधुनिक प्रोसेसर निर्देश पाइपलाइन हैं। उनमें कई भाग होते हैं जो प्रत्येक आंशिक रूप से एक निर्देश को संसाधित करते हैं, अपने परिणामों को पाइपलाइन में अगले चरण में फीड करते हैं, और कार्यक्रम में अगले निर्देश पर काम करना शुरू करते हैं। यह डिज़ाइन एक विशेष अपरिवर्तनीय अनुक्रम में निर्देशों को निष्पादित करने की अपेक्षा करता है। सशर्त शाखा निर्देश इस क्रम को जानना असंभव बनाते हैं। तो सशर्त शाखाएं स्टालों का कारण बन सकती हैं जिसमें कार्यक्रम के एक अलग हिस्से पर पाइपलाइन को पुनरारंभ करना पड़ता है।

शाखाओं से स्टालों को कम करके प्रदर्शन में सुधार
सशर्त शाखाओं से स्टालों को कम करके कई तकनीकें गति में सुधार करती हैं।

शाखा भविष्यवाणी संकेत
ऐतिहासिक रूप से, शाखा भविष्यवाणी ने आँकड़े लिए, और परिणाम का उपयोग कोड को अनुकूलित करने के लिए किया। एक प्रोग्रामर प्रोग्राम के परीक्षण संस्करण को संकलित करेगा, और इसे परीक्षण डेटा के साथ चलाएगा। परीक्षण कोड ने गिना कि शाखाओं को वास्तव में कैसे लिया गया था। जारी किए गए कोड की शाखाओं को अनुकूलित करने के लिए परीक्षण कोड के आंकड़े तब संकलक द्वारा उपयोग किए गए थे। अनुकूलन यह व्यवस्था करेगा कि सबसे तेज़ शाखा दिशा (लिया या नहीं) हमेशा सबसे अधिक बार लिया जाने वाला नियंत्रण प्रवाह पथ होगा। इसकी अनुमति देने के लिए, सीपीयू को पूर्वानुमेय शाखा समय के साथ (या कम से कम) डिज़ाइन किया जाना चाहिए। कुछ सीपीयू में निर्देश सेट होते हैं (जैसे कि पावर आईएसए) जो शाखा संकेत के साथ डिजाइन किए गए थे ताकि एक कंपाइलर सीपीयू को बता सके कि प्रत्येक शाखा को कैसे लिया जाए।

सॉफ़्टवेयर शाखा भविष्यवाणी के साथ समस्या यह है कि इसके लिए एक जटिल सॉफ़्टवेयर विकास प्रक्रिया की आवश्यकता होती है।

हार्डवेयर शाखा भविष्यवक्ता
किसी भी सॉफ़्टवेयर को चलाने के लिए, हार्डवेयर शाखा भविष्यवक्ताओं ने आँकड़ों को इलेक्ट्रॉनिक्स में स्थानांतरित कर दिया। शाखा भविष्यवक्ता एक प्रोसेसर के भाग होते हैं जो एक सशर्त शाखा के परिणाम का अनुमान लगाते हैं। फिर प्रोसेसर का तर्क अपेक्षित निर्देश प्रवाह को निष्पादित करने के लिए शुरुआत से अनुमान लगाता है। एक साधारण हार्डवेयर शाखा भविष्यवाणी योजना का एक उदाहरण यह मान लेना है कि सभी पिछड़ी शाखाएं (यानी एक छोटे प्रोग्राम काउंटर के लिए) ली जाती हैं (क्योंकि वे एक लूप का हिस्सा हैं), और सभी आगे की शाखाएं (एक बड़े प्रोग्राम काउंटर के लिए) नहीं ली जाती हैं (क्योंकि वे एक पाश छोड़ते हैं)। विभिन्न प्रकार के परीक्षण कार्यक्रमों पर अनुकरण में उन्हें चलाकर बेहतर शाखा भविष्यवक्ताओं को विकसित और सांख्यिकीय रूप से मान्य किया जाता है। अच्छे भविष्यवक्ता आमतौर पर किसी शाखा के पिछले निष्पादन के परिणामों की गणना करते हैं। बेहतर शाखा भविष्यवाणी इलेक्ट्रॉनिक्स में निवेश करके तेज़, अधिक महंगे कंप्यूटर तब तेज़ी से चल सकते हैं। हार्डवेयर शाखा भविष्यवाणी के साथ एक सीपीयू में, शाखा संकेत संकलक की संभवतः बेहतर शाखा भविष्यवाणी को हार्डवेयर की अधिक सरलीकृत शाखा भविष्यवाणी को ओवरराइड करने देते हैं।

शाखा-मुक्त कोड
कुछ तर्क शाखाओं के बिना या कम शाखाओं के साथ लिखे जा सकते हैं। शाखाओं के बजाय बिटवाइज़ संचालन, सशर्त चाल या अन्य भविष्यवाणी (कंप्यूटर आर्किटेक्चर) का उपयोग करना अक्सर संभव होता है। वास्तव में, समय पर हमला के कारण क्रिप्टोग्राफी के लिए ब्रांच-फ्री कोड बहुत जरूरी है।

विलंब स्लॉट
एक अन्य तकनीक विलंब स्लॉट है। इस दृष्टिकोण में, शाखा के बाद एक निर्देश हमेशा निष्पादित होता है। इसलिए, कंप्यूटर इस निर्देश का उपयोग उपयोगी कार्य करने के लिए कर सकता है चाहे उसकी पाइपलाइन रुके या नहीं। यह दृष्टिकोण जोखिम कंप्यूटरों में ऐतिहासिक रूप से लोकप्रिय था। संगत सीपीयू के एक परिवार में, यह मल्टीसाइकल सीपीयू (बिना पाइपलाइन के), लंबे समय तक अपेक्षित पाइपलाइनों के साथ तेज सीपीयू, और सुपरस्केलर सीपीयू (जो निर्देशों को क्रम से बाहर कर सकता है) को जटिल बनाता है।

यह भी देखें

 * शाखा विलंब स्लॉट
 * शाखा भविष्यवाणी
 * शाखा तालिका
 * सशर्त (प्रोग्रामिंग)
 * बहाव को काबू करें
 * अप्रत्यक्ष शाखा
 * कार्यक्रम गणक
 * सबरूटीन
 * स्पेगेटी कोड

बाहरी संबंध

 * Free IA-32 and x86-64 documentation, provided by Intel
 * The PDP-11 FAQ
 * The ARM instruction set

Branch (Maschinenbefehl)