जावा बाइटकोड: Difference between revisions

From Vigyanwiki
No edit summary
No edit summary
Line 7: Line 7:


== निर्देश सेट आर्किटेक्चर ==
== निर्देश सेट आर्किटेक्चर ==
जेवीएम [[स्टैक मशीन|स्टैक यंत्र]] और [[रजिस्टर मशीन|रजिस्टर यंत्र]] दोनों है। विधि कॉल के लिए प्रत्येक कॉल स्टैक#STACK-FRAME में ऑपरेंड स्टैक और स्थानीय चर की सरणी होती है।<ref name="jvm">{{cite book |last1=Lindholm |first1=Tim |last2=Yellin |first2=Frank |last3=Bracha |first3=Gilad |last4=Buckley |first4=Alex |title=The Java Virtual Machine Specification |edition=Java SE 8 |date=2015-02-13 |url=http://docs.oracle.com/javase/specs/jvms/se8/html/}}</ref>{{rp|2.6}} ऑपरेंड स्टैक का उपयोग ऑपरेशंस के लिए कंप्यूटेशंस के लिए किया जाता है और कॉल की गई विधि के रिटर्न वैल्यू को प्राप्त करने के लिए किया जाता है, जबकि स्थानीय चर [[प्रोसेसर रजिस्टर]] के समान उद्देश्य की सेवा करते हैं और विधि तर्कों को पारित करने के लिए भी उपयोग किए जाते हैं। संकलक द्वारा गणना किए गए ऑपरेंड स्टैक और स्थानीय चर सरणी का अधिकतम आकार प्रत्येक विधि की विशेषताओं का हिस्सा है।<ref name="jvm" />{{rp|4.7.3}} प्रत्येक को स्वतंत्र रूप से 0 से 65535 मानों के आकार में रखा जा सकता है, जहां प्रत्येक मान 32 बिट्स है। {{code|lang="java"|long}} और {{code|lang="java"|double}} प्रकार, जो 64 बिट हैं, लगातार दो स्थानीय चर लेते हैं<ref name="jvm"/>{{rp|2.6.1}} (जिन्हें स्थानीय चर सरणी में 64-बिट संरेखित करने की आवश्यकता नहीं है) या ऑपरेंड स्टैक में मान (लेकिन स्टैक की गहराई में दो इकाइयों के रूप में गिना जाता है)।<ref name="jvm"/>{{rp|2.6.2}}
जेवीएम [[स्टैक मशीन|स्टैक यंत्र]] और [[रजिस्टर मशीन|रजिस्टर यंत्र]] दोनों है। विधि कॉल के प्रत्येक फ्रेम में एक ऑपरेंड स्टैक और स्थानीय चर की एक सरणी होती है।<ref name="jvm">{{cite book |last1=Lindholm |first1=Tim |last2=Yellin |first2=Frank |last3=Bracha |first3=Gilad |last4=Buckley |first4=Alex |title=The Java Virtual Machine Specification |edition=Java SE 8 |date=2015-02-13 |url=http://docs.oracle.com/javase/specs/jvms/se8/html/}}</ref>{{rp|2.6}} ऑपरेंड स्टैक का उपयोग ऑपरेशंस के लिए कंप्यूटेशंस के लिए किया जाता है और कॉल की गई विधि के रिटर्न मान को प्राप्त करने के लिए किया जाता है, जबकि स्थानीय चर [[प्रोसेसर रजिस्टर]] के समान उद्देश्य की सेवा करते हैं और विधि तर्कों को पारित करने के लिए भी उपयोग किए जाते हैं। संकलक द्वारा गणना किए गए ऑपरेंड स्टैक और स्थानीय चर सरणी का अधिकतम आकार प्रत्येक विधि की विशेषताओं का भाग है।<ref name="jvm" />{{rp|4.7.3}} प्रत्येक को स्वतंत्र रूप से 0 से 65535 मानों के आकार में रखा जा सकता है, जहां प्रत्येक मान 32 बिट्स है। {{code|lang="java"|long}} और {{code|lang="java"|double}} प्रकार, जो 64 बिट हैं, लगातार दो स्थानीय चर लेते हैं<ref name="jvm"/>{{rp|2.6.1}} (जिन्हें स्थानीय चर सरणी में 64-बिट संरेखित करने की आवश्यकता नहीं है) या ऑपरेंड स्टैक में मान (लेकिन स्टैक की गहराई में दो इकाइयों के रूप में गिना जाता है)।<ref name="jvm"/>{{rp|2.6.2}}




=== निर्देश सेट ===
=== निर्देश सेट ===
{{further|List of Java bytecode instructions}}
{{further|जावा बाइटकोड निर्देशों की सूची}}
प्रत्येक बाइटकोड बाइट से बना होता है जो ऑपरेंड के लिए शून्य या अधिक बाइट्स के साथ [[opcode]] का प्रतिनिधित्व करता है।<ref name="jvm"/>{{rp|2.11}}
प्रत्येक बाइटकोड बाइट से बना होता है जो ऑपरेंड के लिए शून्य या अधिक बाइट्स के साथ [[opcode|ओपकोड]] का प्रतिनिधित्व करता है।<ref name="jvm"/>{{rp|2.11}}
256 संभावित बाइट-लॉन्ग ऑपकोड में से, {{as of|2015|lc=y}}, 202 उपयोग में हैं (~79%), 51 भविष्य में उपयोग के लिए आरक्षित हैं (~20%), और 3 निर्देश (~1%) उपयोग के लिए जेवीएम कार्यान्वयन के लिए स्थायी रूप से आरक्षित हैं।<ref name="jvm"/>{{rp|6.2}} इनमें से दो (<code>impdep1</code> और <code>impdep2</code>) क्रमशः कार्यान्वयन-विशिष्ट सॉफ़्टवेयर और हार्डवेयर के लिए ट्रैप प्रदान करना है। ब्रेकप्वाइंट को लागू करने के लिए तीसरे का उपयोग डिबगर्स के लिए किया जाता है।
 
2015 तक 256 संभावित बाइट-लॉन्ग ऑपकोड में से 202 उपयोग (~79%) में हैं, 51 भविष्य में उपयोग (~20%) के लिए आरक्षित हैं, और 3 निर्देश (~1%) उपयोग के लिए जेवीएम कार्यान्वयन के लिए स्थायी रूप से आरक्षित हैं।<ref name="jvm" />{{rp|6.2}} इनमें से दो (<code>impdep1</code> और <code>impdep2</code>) क्रमशः कार्यान्वयन-विशिष्ट सॉफ़्टवेयर और हार्डवेयर के लिए ट्रैप प्रदान करना है। ब्रेकप्वाइंट को प्रायुक्त करने के लिए तीसरे का उपयोग डिबगर्स के लिए किया जाता है।


निर्देश कई व्यापक समूहों में आते हैं:
निर्देश कई व्यापक समूहों में आते हैं:
Line 24: Line 25:
* विधि मंगलाचरण और वापसी (उदा। <code>invokespecial</code>, <code>areturn</code>)
* विधि मंगलाचरण और वापसी (उदा। <code>invokespecial</code>, <code>areturn</code>)


अपवाद फेंकने, सिंक्रनाइज़ेशन इत्यादि जैसे कई विशिष्ट कार्यों के लिए कुछ निर्देश भी हैं।
अपवाद फेंकने, समक्रमण इत्यादि जैसे कई विशिष्ट कार्यों के लिए कुछ निर्देश भी हैं।


कई निर्देशों में उपसर्ग और/या प्रत्यय होते हैं जो उनके द्वारा संचालित ऑपरेंड के प्रकारों का जिक्र करते हैं।<ref name="jvm"/>{{rp|2.11.1}} ये इस प्रकार हैं:
कई निर्देशों में उपसर्ग और/या प्रत्यय होते हैं जो उनके द्वारा संचालित ऑपरेंड के प्रकारों का जिक्र करते हैं।<ref name="jvm"/>{{rp|2.11.1}} ये इस प्रकार हैं:
Line 30: Line 31:
{| class="wikitable"
{| class="wikitable"
|-
|-
! Prefix/suffix !! Operand type
! उपसर्ग/प्रत्यय !! ऑपरेंड प्रकार
|-
|-
| <code>i</code> || integer
| <code>i</code> || पूर्णांक
|-
|-
| <code>l</code> || long
| <code>l</code> || लॉन्ग
|-
|-
| <code>s</code> || short
| <code>s</code> || शार्ट
|-
|-
| <code>b</code> || byte
| <code>b</code> || बाइट
|-
|-
| <code>c</code> || character
| <code>c</code> || करैक्टर
|-
|-
| <code>f</code> || float
| <code>f</code> || फ्लोट
|-
|-
| <code>d</code> || double
| <code>d</code> || डबल
|-
|-
| <code>a</code> || reference
| <code>a</code> || रिफरेन्स
|}
|}
उदाहरण के लिए, <code>iadd</code> दो पूर्णांक जोड़ देगा, जबकि <code>dadd</code> दो युगल जोड़ेंगे। <code>const</code>का>, <code>load</code>, और <code>store</code> निर्देश प्रपत्र का प्रत्यय भी ले सकते हैं <code>_''n''</code>, जहाँ n 0–3 के लिए संख्या है <code>load</code> और <code>store</code>. के लिए अधिकतम एन <code>const</code> प्रकार से भिन्न होता है। <code>const</code> ई> निर्देश स्टैक पर निर्दिष्ट प्रकार के मान को पुश करते हैं। उदाहरण के लिए, <code>iconst_5</code> स्टैक पर मान 5 के साथ पूर्णांक (32 बिट मान) पुश करेगा, जबकि <code>dconst_1</code> स्टैक पर मान 1 के साथ डबल (64 बिट फ्लोटिंग पॉइंट वैल्यू) पुश करेगा। भी है <code>aconst_null</code>, जो धक्का देता है {{code|lang=java|null}} संदर्भ। एन के लिए <code>load</code> और <code>store</code> निर्देश लोड करने या स्टोर करने के लिए स्थानीय चर सरणी में इंडेक्स निर्दिष्ट करता है। <code>aload_0</code> e> निर्देश ऑब्जेक्ट को स्थानीय चर 0 में स्टैक पर धकेलता है (यह आमतौर पर <code>[[this (computer programming)|this]]</code> वस्तु)। <code>istore_1</code> स्टैक के शीर्ष पर पूर्णांक को स्थानीय चर 1 में संग्रहीत करता है। 3 से अधिक स्थानीय चर के लिए प्रत्यय हटा दिया जाता है और ऑपरेंड का उपयोग किया जाना चाहिए।
उदाहरण के लिए, <code>iadd</code> दो पूर्णांक जोड़ देगा, जबकि <code>dadd</code> दो युगल जोड़ेंगे। <code>const</code>का>, <code>load</code>, और <code>store</code> निर्देश प्रपत्र का प्रत्यय भी ले सकते हैं <code>_''n''</code>, जहाँ n 0–3 के लिए संख्या है <code>load</code> और <code>store</code>. के लिए अधिकतम एन <code>const</code> प्रकार से भिन्न होता है। <code>const</code> ई> निर्देश स्टैक पर निर्दिष्ट प्रकार के मान को पुश करते हैं। उदाहरण के लिए, <code>iconst_5</code> स्टैक पर मान 5 के साथ पूर्णांक (32 बिट मान) पुश करेगा, जबकि <code>dconst_1</code> स्टैक पर मान 1 के साथ डबल (64 बिट फ्लोटिंग पॉइंट मान) पुश करेगा। भी है <code>aconst_null</code>, जो धक्का देता है {{code|lang=java|null}} संदर्भ। एन के लिए <code>load</code> और <code>store</code> निर्देश लोड करने या स्टोर करने के लिए स्थानीय चर सरणी में इंडेक्स निर्दिष्ट करता है। <code>aload_0</code> e> निर्देश ऑब्जेक्ट को स्थानीय चर 0 में स्टैक पर धकेलता है (यह आमतौर पर <code>[[this (computer programming)|this]]</code> वस्तु)। <code>istore_1</code> स्टैक के शीर्ष पर पूर्णांक को स्थानीय चर 1 में संग्रहीत करता है। 3 से अधिक स्थानीय चर के लिए प्रत्यय हटा दिया जाता है और ऑपरेंड का उपयोग किया जाना चाहिए।


== उदाहरण ==
== उदाहरण ==
Line 97: Line 98:
*[[Jikes]], Java से Java bytecode में संकलित (IBM द्वारा विकसित, C++ में कार्यान्वित)
*[[Jikes]], Java से Java bytecode में संकलित (IBM द्वारा विकसित, C++ में कार्यान्वित)
* एस्प्रेसो, जावा से जावा बाइटकोड में संकलित (केवल जावा 1.0)
* एस्प्रेसो, जावा से जावा बाइटकोड में संकलित (केवल जावा 1.0)
* जावा के लिए GNU कम्पाइलर (GCJ), जावा से जावा बाइटकोड में संकलित करता है; यह देशी [[मशीन कोड|यंत्र कोड]] को भी संकलित कर सकता है और संस्करण 6 तक जीएनयू संकलक संग्रह (जीसीसी) का हिस्सा था।
* जावा के लिए GNU कम्पाइलर (GCJ), जावा से जावा बाइटकोड में संकलित करता है; यह देशी [[मशीन कोड|यंत्र कोड]] को भी संकलित कर सकता है और संस्करण 6 तक जीएनयू संकलक संग्रह (जीसीसी) का भाग था।


कुछ प्रोजेक्ट जावा असेंबलर प्रदान करते हैं ताकि जावा बाइटकोड को हाथ से लिखने में सक्षम बनाया जा सके। यंत्र द्वारा असेंबली कोड भी उत्पन्न किया जा सकता है, उदाहरण के लिए जावा आभासी यंत्र को लक्षित करने वाले संकलक द्वारा। उल्लेखनीय जावा कोडांतरकों में शामिल हैं:
कुछ प्रोजेक्ट जावा असेंबलर प्रदान करते हैं ताकि जावा बाइटकोड को हाथ से लिखने में सक्षम बनाया जा सके। यंत्र द्वारा असेंबली कोड भी उत्पन्न किया जा सकता है, उदाहरण के लिए जावा आभासी यंत्र को लक्षित करने वाले संकलक द्वारा। उल्लेखनीय जावा कोडांतरकों में शामिल हैं:

Revision as of 16:38, 3 March 2023

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

जावा से संबंध

जावा (प्रोग्रामिंग भाषा) प्रोग्रामर के जावा बाइटकोड के बारे में जानने या समझने की बिल्कुल भी आवश्यकता नहीं है। चूंकि, जैसा कि आईबीएम विकासक निर्माणकर्ता पत्रिका में सुझाव दिया गया है, कि बाइटकोड को समझना और जावा संकलक द्वारा बाइटकोड उत्पन्न होने की संभावना जावा प्रोग्रामर को उसी प्रकार सहायता करती है जैसे असेंबली भाषा का ज्ञान सी (प्रोग्रामिंग भाषा) या सी ++ प्रोग्रामर को सहायता करता है।[1]


निर्देश सेट आर्किटेक्चर

जेवीएम स्टैक यंत्र और रजिस्टर यंत्र दोनों है। विधि कॉल के प्रत्येक फ्रेम में एक ऑपरेंड स्टैक और स्थानीय चर की एक सरणी होती है।[2]: 2.6  ऑपरेंड स्टैक का उपयोग ऑपरेशंस के लिए कंप्यूटेशंस के लिए किया जाता है और कॉल की गई विधि के रिटर्न मान को प्राप्त करने के लिए किया जाता है, जबकि स्थानीय चर प्रोसेसर रजिस्टर के समान उद्देश्य की सेवा करते हैं और विधि तर्कों को पारित करने के लिए भी उपयोग किए जाते हैं। संकलक द्वारा गणना किए गए ऑपरेंड स्टैक और स्थानीय चर सरणी का अधिकतम आकार प्रत्येक विधि की विशेषताओं का भाग है।[2]: 4.7.3  प्रत्येक को स्वतंत्र रूप से 0 से 65535 मानों के आकार में रखा जा सकता है, जहां प्रत्येक मान 32 बिट्स है। long और double प्रकार, जो 64 बिट हैं, लगातार दो स्थानीय चर लेते हैं[2]: 2.6.1  (जिन्हें स्थानीय चर सरणी में 64-बिट संरेखित करने की आवश्यकता नहीं है) या ऑपरेंड स्टैक में मान (लेकिन स्टैक की गहराई में दो इकाइयों के रूप में गिना जाता है)।[2]: 2.6.2 


निर्देश सेट

प्रत्येक बाइटकोड बाइट से बना होता है जो ऑपरेंड के लिए शून्य या अधिक बाइट्स के साथ ओपकोड का प्रतिनिधित्व करता है।[2]: 2.11 

2015 तक 256 संभावित बाइट-लॉन्ग ऑपकोड में से 202 उपयोग (~79%) में हैं, 51 भविष्य में उपयोग (~20%) के लिए आरक्षित हैं, और 3 निर्देश (~1%) उपयोग के लिए जेवीएम कार्यान्वयन के लिए स्थायी रूप से आरक्षित हैं।[2]: 6.2  इनमें से दो (impdep1 और impdep2) क्रमशः कार्यान्वयन-विशिष्ट सॉफ़्टवेयर और हार्डवेयर के लिए ट्रैप प्रदान करना है। ब्रेकप्वाइंट को प्रायुक्त करने के लिए तीसरे का उपयोग डिबगर्स के लिए किया जाता है।

निर्देश कई व्यापक समूहों में आते हैं:

  • लोड और स्टोर (उदा। aload_0, istore)
  • अंकगणित और तर्क (उदा. ladd, fcmpl)
  • प्रकार रूपांतरण (उदा. i2b, d2i)
  • वस्तु निर्माण और हेरफेर (new, putfield)
  • ऑपरेंड स्टैक प्रबंधन (उदा। swap, dup2)
  • नियंत्रण हस्तांतरण (उदा। ifeq, goto)
  • विधि मंगलाचरण और वापसी (उदा। invokespecial, areturn)

अपवाद फेंकने, समक्रमण इत्यादि जैसे कई विशिष्ट कार्यों के लिए कुछ निर्देश भी हैं।

कई निर्देशों में उपसर्ग और/या प्रत्यय होते हैं जो उनके द्वारा संचालित ऑपरेंड के प्रकारों का जिक्र करते हैं।[2]: 2.11.1  ये इस प्रकार हैं:

उपसर्ग/प्रत्यय ऑपरेंड प्रकार
i पूर्णांक
l लॉन्ग
s शार्ट
b बाइट
c करैक्टर
f फ्लोट
d डबल
a रिफरेन्स

उदाहरण के लिए, iadd दो पूर्णांक जोड़ देगा, जबकि dadd दो युगल जोड़ेंगे। constका>, load, और store निर्देश प्रपत्र का प्रत्यय भी ले सकते हैं _n, जहाँ n 0–3 के लिए संख्या है load और store. के लिए अधिकतम एन const प्रकार से भिन्न होता है। const ई> निर्देश स्टैक पर निर्दिष्ट प्रकार के मान को पुश करते हैं। उदाहरण के लिए, iconst_5 स्टैक पर मान 5 के साथ पूर्णांक (32 बिट मान) पुश करेगा, जबकि dconst_1 स्टैक पर मान 1 के साथ डबल (64 बिट फ्लोटिंग पॉइंट मान) पुश करेगा। भी है aconst_null, जो धक्का देता है null संदर्भ। एन के लिए load और store निर्देश लोड करने या स्टोर करने के लिए स्थानीय चर सरणी में इंडेक्स निर्दिष्ट करता है। aload_0 e> निर्देश ऑब्जेक्ट को स्थानीय चर 0 में स्टैक पर धकेलता है (यह आमतौर पर this वस्तु)। istore_1 स्टैक के शीर्ष पर पूर्णांक को स्थानीय चर 1 में संग्रहीत करता है। 3 से अधिक स्थानीय चर के लिए प्रत्यय हटा दिया जाता है और ऑपरेंड का उपयोग किया जाना चाहिए।

उदाहरण

निम्नलिखित जावा कोड पर विचार करें:

<वाक्यविन्यास प्रकाश लैंग = जावा> बाहरी: के लिए (int i = 2; i <1000; i++) {

   के लिए (int j = 2; j <i; j++) {
       अगर (मैं% जे == 0)
           बाहरी जारी रखें;
   }
   System.out.println (i);

} </वाक्यविन्यास हाइलाइट>

जावा संकलक ऊपर दिए गए जावा कोड को बाइटकोड में निम्नानुसार अनुवादित कर सकता है, यह मानते हुए कि ऊपर विधि में रखा गया था: <वाक्यविन्यास लैंग = जैस्मीन> 0: आइकॉनस्ट_2 1: आईस्टोर_1 2: iload_1 3: सिपुश 1000 6: if_icmpge 44 9: आइकनस्ट_2 10: आइस्टोर_2 11: iload_2 12: iload_1 13: if_icmpge 31 16: iload_1 17: iload_2 18: इरेम 19 : यदि 25 22: गोटो 38 25: आईएनसी 2, 1 28: गोटो 11 31: गेटस्टैटिक #84; // फील्ड जावा/लैंग/सिस्टम.आउट: लाजावा/आईओ/प्रिंटस्ट्रीम; 34: iload_1 35: इनवोकआभासी #85; // विधि जावा/io/PrintStream.println:(I)V 38: आईएनसी 1, 1 41: गोटो 2 44: रिटर्न </ सिंटैक्स हाइलाइट>

पीढ़ी

javac बाइटकोड का निर्माण करके जावा आभासी यंत्र को लक्षित करने वाली सबसे आम भाषा जावा है। मूल रूप से केवल संकलक मौजूद था, सन माइक्रोसिस्टम्स से जावैक संकलक, जो जावा स्रोत कोड को जावा बाइटकोड में संकलित करता है; लेकिन क्योंकि जावा बाइटकोड के लिए सभी विनिर्देश अब उपलब्ध हैं, अन्य पार्टियों ने संकलक्स की आपूर्ति की है जो जावा बाइटकोड का उत्पादन करते हैं। अन्य संकलक के उदाहरणों में शामिल हैं:

  • जावा के लिए एक्लिप्स संकलक (ECJ)
  • Jikes, Java से Java bytecode में संकलित (IBM द्वारा विकसित, C++ में कार्यान्वित)
  • एस्प्रेसो, जावा से जावा बाइटकोड में संकलित (केवल जावा 1.0)
  • जावा के लिए GNU कम्पाइलर (GCJ), जावा से जावा बाइटकोड में संकलित करता है; यह देशी यंत्र कोड को भी संकलित कर सकता है और संस्करण 6 तक जीएनयू संकलक संग्रह (जीसीसी) का भाग था।

कुछ प्रोजेक्ट जावा असेंबलर प्रदान करते हैं ताकि जावा बाइटकोड को हाथ से लिखने में सक्षम बनाया जा सके। यंत्र द्वारा असेंबली कोड भी उत्पन्न किया जा सकता है, उदाहरण के लिए जावा आभासी यंत्र को लक्षित करने वाले संकलक द्वारा। उल्लेखनीय जावा कोडांतरकों में शामिल हैं:

  • जैस्मीन (जावा असेंबलर), जावा कक्षाओं के लिए पाठ विवरण लेता है, जावा आभासी यंत्र इंस्ट्रक्शन सेट का उपयोग करके साधारण असेंबली-जैसे सिंटैक्स में लिखा जाता है और जावा क्लास फ़ाइल उत्पन्न करता है[3]
  • जमैका, जावा आभासी यंत्र के लिए मैक्रो (कंप्यूटर साइंस) असेंबली भाषा। जावा सिंटैक्स का उपयोग क्लास या इंटरफ़ेस परिभाषा के लिए किया जाता है। विधि निकायों को बाइटकोड निर्देशों का उपयोग करके निर्दिष्ट किया गया है।[4]
  • Krakatau Bytecode Tools, में वर्तमान में तीन टूल हैं: जावा क्लासफाइल्स के लिए डीकंपलर और डिस्सेबलर और क्लासफाइल्स बनाने के लिए असेंबलर।[5]
  • लिलाक, जावा आभासी यंत्र के लिए असेंबलर और डिसअसेंबलर।[6]

दूसरों ने जावा आभासी यंत्र को लक्षित करने के लिए विभिन्न प्रोग्रामिंग भाषाओं के लिए संकलक विकसित किए हैं, जैसे:


निष्पादन

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

गतिशील भाषाओं के लिए समर्थन

जावा आभासी यंत्र टाइप सिस्टम#डायनामिक टाइपिंग के लिए कुछ सहायता प्रदान करती है। अधिकांश मौजूदा जेवीएम निर्देश सेट टाइप सिस्टम # स्टेटिक टाइपिंग है - इस अर्थ में कि मेथड कॉल में उनके हस्ताक्षर संकलन समय पर टाइप-चेक किए जाते हैं, बिना किसी तंत्र के रन टाइम (प्रोग्राम जीवनचक्र चरण) के लिए इस निर्णय को स्थगित करने के लिए, या चुनने के लिए वैकल्पिक दृष्टिकोण द्वारा विधि प्रेषण।[9] जावा सामुदायिक प्रक्रिया 292 (जावा प्लेटफॉर्म पर गतिशील रूप से टाइप की गई भाषाओं का समर्थन)[10] नया जोड़ा invokedynamic जेवीएम स्तर पर निर्देश, डायनेमिक टाइप सिस्टम # टाइप चेकिंग पर निर्भर विधि आमंत्रण की अनुमति देने के लिए (मौजूदा स्टेटिकली टाइप-चेक के बजाय) invokevirtual निर्देश)। दा विंची यंत्र प्रोटोटाइप आभासी यंत्र कार्यान्वयन है जो गतिशील भाषाओं का समर्थन करने के उद्देश्य से जेवीएम एक्सटेंशन को होस्ट करता है। जावा प्लेटफॉर्म, मानक संस्करण 7 का समर्थन करने वाले सभी जेवीएम में भी शामिल हैं invokedynamic opcode.

यह भी देखें

संदर्भ

  1. "IBM Developer". developer.ibm.com. Retrieved 20 February 2006.{{cite web}}: CS1 maint: url-status (link)
  2. 2.0 2.1 2.2 2.3 2.4 2.5 2.6 Lindholm, Tim; Yellin, Frank; Bracha, Gilad; Buckley, Alex (2015-02-13). The Java Virtual Machine Specification (Java SE 8 ed.).
  3. Jasmin home page
  4. Jamaica: The Java virtual machine (JVM) macro assembler
  5. Krakatau home page
  6. Lilac home page
  7. Free Pascal 3.0 release notes
  8. Free Pascal JVM Target
  9. Nutter, Charles (2007-01-03). "InvokeDynamic: Actually Useful?". Retrieved 2008-01-25.
  10. see JSR 292


बाहरी संबंध