मशीन कोड

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

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

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

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

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

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

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

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

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

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

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

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

आरएस, आरटी, और आरडी रजिस्टर ऑपरेंड को इंगित करते हैं; 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 के दशक में, ओवरलैपिंग निर्देशों का उपयोग कभी -कभी मेमोरी स्पेस को संरक्षित करने के लिए किया जाता था।एक उदाहरण Microsoft के Altair Basic में त्रुटि तालिकाओं के कार्यान्वयन में थे, जहां इंटरलेव्ड निर्देशों ने पारस्परिक रूप से अपने निर्देश बाइट्स को साझा किया। तकनीक का आज शायद ही कभी उपयोग किया जाता है, लेकिन अभी भी उन क्षेत्रों का सहारा लेना आवश्यक है जहां आकार के लिए चरम अनुकूलन बाइट-स्तर पर आवश्यक है जैसे कि बूट लोडर के कार्यान्वयन में जो बूट क्षेत्रों में फिट होना पड़ता है।

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

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

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

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

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

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

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

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

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

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

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

यह भी देखें

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