मशीन कोड

मशीन कोड किसी भी कंप्यूटर प्रोग्रामिंग की निम्न-स्तरीय प्रोग्रामिंग भाषा होती हैl इसमें मशीन की भाषा निर्देश बहुत महत्वपूर्ण होता हैं, जिसका उपयोग कंप्यूटर की केंद्रीय प्रसंस्करण इकाई सीपीयू को नियंत्रित करने के लिए किया जाता है। प्रत्येक निर्देश सीपीयू को सीपीयू के रजिस्टरों या मेमोरी में डेटा की एक या अधिक इकाइयों पर लोड, स्टोर, जंप, या अंकगणितीय तर्क इकाई एएलयू जैसे ऑपरेशन को बहुत विशिष्ट कार्य करने का कारण बनाता है।

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

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

मशीन कोड प्रोग्रामर के लिए दिखाई देने वाले प्रोग्रामिंग डिटेल के निम्नतम स्तर की परिभाषा के अनुसार है, लेकिन आंतरिक रूप से कई प्रोसेसर माइक्रोकोड का उपयोग करते हैं या मशीन कोड निर्देशों को माइक्रो-ऑपरेशन के अनुक्रमों में माइक्रो-ऑप्स की तरह अनुकूलित और रूपांतरित करते हैं। यह आमतौर पर मशीन कोड नहीं माना जाता है।

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

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

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

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

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

असेंबली भाषाएँ
मशीन भाषा का एक बहुत अधिक मानव अनुकूल प्रतिपादन, जिसे असेंबली भाषा कहा जाता हैl मशीन कोड निर्देशों को संदर्भित करने के लिए स्मृति सहायक (मनमोनिक) कोड का उपयोग करता हैl यह बजाय सीधे निर्देशों के संख्यात्मक मूल्यों का उपयोग करने के लिए, और भंडारण स्थानों और कभी -कभी रजिस्टरों को संदर्भित करने के लिए प्रतीकात्मक नामों का उपयोग करता है। उदाहरण के लिए, Zilog Z80 प्रोसेसर, मशीन कोड पर 00000101, जिसके कारण सीपीयू B प्रोसेसर रजिस्टर के अपक्षय का कारण बनता है और असेंबली भाषा में  DEC B के नाम से जाना जाता है।

उदाहरण
एमआईपीएस (MIPS) आर्किटेक्चर मशीन कोड के लिए एक विशिष्ट उदाहरण प्रदान करता है जिसके निर्देश हमेशा 32 बिट्स लंबे होते हैं। सामान्य प्रकार का निर्देश ओपी (ऑपरेशन) फ़ील्ड, उच्चतम 6 बिट्स द्वारा दिया जाता है। जे-टाइप (कूद) और आई-टाइप (तत्काल) निर्देश पूरी तरह से ओपी द्वारा निर्दिष्ट हैं। आर-टाइप (रजिस्टर) निर्देशों में सटीक ऑपरेशन निर्धारित करने के लिए एक अतिरिक्त फ़ील्ड फ़ंक्शन शामिल है। इन प्रकारों में उपयोग किए जाने वाले क्षेत्र हैं:

6       5        5         5           5           6      बिट्स [ओपी |    रु   ।   आरटी  |   RD    |    SHAMT   |   funct  ] आर- प्रकार [ओपी |    रु   ।   आरटी  |           पता/तत्काल             ]  आई- प्रकार [ओपी |                         लक्ष्य पता                    ]  जे-प्रकार

आरएस, आरटी, और आरडी रजिस्टर ऑपरेंड को इंगित करते हैं; Shamt एक शिफ्ट राशि देता है, और पते या तत्काल फ़ील्ड में सीधे एक ऑपरेंड होता है।

उदाहरण के लिए, रजिस्टर 1 और 2 को जोड़ना और परिणाम को रजिस्टर 6 में रखना एन्कोड किया गया है:

[ओपी |   रु   ।    आर टी   |  RD       |  SHAMT   | फंक्शनल] 0     1         2         6              0          32    दशमलव 000000 00001     00010      00110        00000     100000    बाइनरी

रजिस्टर 8 में सूचीबद्ध स्थान के बाद मेमोरी सेल 68 कोशिकाओं से लिया गया रजिस्टर 8 में एक मान लोड करें:

[ ओपी |   रु     ।   आरटी    |       पता/तत्काल      ] 35      3         8                 68            दशमलव 100011  00011      01000       00000 00001 000100   बाइनरी

पते पर कूदना 1024:

[ओपी   |           लक्ष्य पता             ] 2                1024                    दशमलव 000010  00000 00000 00000 10000 000000      बाइनरी

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

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

यह कभी -कभी एक कोड ऑब्फ़स्केशन तकनीक के रूप में भी उपयोग किया जाता है, जो कि डिस्सैम और छेड़छाड़ के खिलाफ एक उपाय के रूप में होता है।

सिद्धांत का उपयोग वसा बायनेरिज़ के साझा कोड अनुक्रमों में भी किया जाता है जो कई निर्देश-सेट-असंगत प्रोसेसर प्लेटफार्मों पर चलना चाहिए।

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

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

एमुलेटर को लागू करने के लिए माइक्रोकोड का उपयोग करना कंप्यूटर को पूरी तरह से अलग कंप्यूटर की वास्तुकला को प्रस्तुत करने में सक्षम बनाता है। सिस्टम/360 लाइन ने इसका उपयोग पहले आईबीएम मशीनों से कंप्यूटर के नए परिवार के लिए पोर्टिंग कार्यक्रमों की अनुमति देने के लिए किया था, उदाहरण IBM 1400 श्रृंखला | IBM 1401/1440/1460 IBM S/360 मॉडल 40 पर एमुलेटर।

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

मशीन कोड और असेंबली कोड को कभी-कभी देशी कोड कहा जाता है जब भाषा सुविधाओं या पुस्तकालयों के प्लेटफ़ॉर्म-निर्भर भागों का उल्लेख किया जाता है।

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

एक प्रक्रिया के दृष्टिकोण से, कोड स्थान अपने पता स्थान का हिस्सा होता है जहां निष्पादन में कोड संग्रहीत है। मल्टीटास्किंग सिस्टम में इसमें प्रोग्राम के कोड सेगमेंट और आमतौर पर साझा किए गए लाइब्रेरी शामिल होती हैं। मल्टी-थ्रेडिंग के वातावरण में, प्रक्रिया के अलग-अलग थ्रेड्स डेटा स्पेस के साथ-साथ कोड स्पेस को साझा करते हैं, जो प्रक्रिया स्विचिंग की तुलना में संदर्भ स्विचिंग के ओवरहेड को कम करता है।

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

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

यह भी देखें

 * सभा की भाषा
 * एंडियननेस
 * मशीन भाषाओं की सूची
 * मशीन कोड मॉनिटर
 * ओवरहेड कोड
 * पी-कोड मशीन
 * कम निर्देश सेट कंप्यूटिंग (RISC)
 * बहुत लंबा निर्देश शब्द
 * शिक्षण मशीन कोड: माइक्रो-प्रोफेसर MPF-I