ज्वाइन जावा: Difference between revisions
No edit summary |
No edit summary |
||
Line 8: | Line 8: | ||
}} | }} | ||
'''ज्वाइन जावा''' एक [[ प्रोग्रामिंग भाषा |प्रोग्रामिंग | '''ज्वाइन जावा''' एक [[ प्रोग्रामिंग भाषा |प्रोग्रामिंग लैंग्वेज]] है जो [[ सम्मिलित-पैटर्न ]] पर आधारित है जो [[ जोड़-गणना |जोड़-गणना]] के ज्वाइन शब्दार्थ के साथ मानक [[ जावा (प्रोग्रामिंग भाषा) | जावा]] का विस्तार करती है। यह [[दक्षिण ऑस्ट्रेलिया विश्वविद्यालय]] में डॉ. वॉन इट्ज़स्टीन द्वारा रीकॉन्फिगरेबल कंप्यूटिंग लैब के भीतर लिखा गया था। | ||
== | == लैंग्वेज की विशेषताएं == | ||
ज्वाइन जावा विस्तारण तीन नए | ज्वाइन जावा विस्तारण तीन नए लैंग्वेज निर्माणों का परिचय देता है: | ||
* ज्वाइन के तरीके | * ज्वाइन के तरीके | ||
* एसिंक्रोनस तरीके | * एसिंक्रोनस तरीके | ||
* पैटर्न के मिलान के क्रम को निर्धारित करने के लिए वर्ग संशोधक का क्रम निर्धारित करें | * पैटर्न के मिलान के क्रम को निर्धारित करने के लिए वर्ग संशोधक का क्रम निर्धारित करें | ||
सबसे लोकप्रिय प्रोग्रामिंग | सबसे लोकप्रिय प्रोग्रामिंग लैंग्वेज में संगामिति को सेमाफोर और मॉनिटर जैसे निर्माणों का उपयोग करके कार्यान्वित किया जाता है। लाइब्रेरीज बन रहे हैं (जैसे जावा संगामिति लाइब्रेरीज जेएसआर-166) जो उच्च-स्तरीय संगामिति शब्दार्थ प्रदान करते हैं। संचार अनुक्रमिक प्रक्रियाओं (सीएसपी), संचार प्रणाली की गणना (सीसीएस) और पीआई में समवर्ती प्रक्रियाओं के अंतरापृष्ठ पर घटनाओं की संरचना के माध्यम से स्पष्ट रूप से परिभाषित उच्च-स्तरीय समकालीन व्यवहार होते हैं। इसके विपरीत, ज्वाइन गणना में, कमी नियमों के रूप में परिभाषित घटनाओं के स्थानीय संयोजन के आधार पर स्पष्ट समकालीन है। जोड़ना शब्दार्थ प्रक्रियाओं और चैनलों के गतिशील निर्माण और विनाश सहित मॉड्यूलर के वस्तु-उन्मुख विचार को भंग किए बिना समकालीन की स्पष्ट अभिव्यक्ति प्रदान करने का प्रयास करते हैं। | ||
ज्वाइन जावा | ज्वाइन जावा लैंग्वेज वस्तुतः सभी प्रकाशित समवर्ती पैटर्न को निम्न-स्तरीय मॉनिटर कॉल के लिए स्पष्ट सहारा के बिना व्यक्त कर सकती है। सामान्य तौर पर, जावा प्रोग्राम में सम्मिलित हों उनके जावा समकक्षों की तुलना में अधिक संक्षिप्त हैं। ज्वाइन जावा में प्रारम्भ किए गए अतिरिक्त को ज्वाइन कैलकुलस से प्राप्त उच्च-स्तरीय अभिव्यक्तियों द्वारा प्रबंधित किया जा सकता है। मॉनिटर (प्रतीक्षा करें और सूचित करें) से जुड़े समकालीन एक्सप्रेशन जो सामान्य रूप से मेथड के निकाय में स्थित होते हैं, उन्हें ज्वाइन जावा अभिव्यक्ति (ज्वाइन तरीकों) से बदला जा सकता है जो तरीका हस्ताक्षर का हिस्सा बनते हैं। | ||
=== ज्वाइन के तरीके === | === ज्वाइन के तरीके === | ||
Line 63: | Line 63: | ||
== संबंधित भाषाएँ == | == संबंधित भाषाएँ == | ||
[[ पॉलीफोनिक सी तेज | पॉलीफोनिक सी शार्प]] निकटतम संबंधित | [[ पॉलीफोनिक सी तेज | पॉलीफोनिक सी शार्प]] निकटतम संबंधित लैंग्वेज है।<br>सीω पॉलीफोनिक सी शार्प का उत्तराधिकारी है। | ||
[[हार्डवेयर जावा में शामिल हों]] लैंग्वेज को आगे बढ़ाया हार्डवेयर शब्दार्थ को लागू करने के लिए ज्वाइन जावा। इस | [[हार्डवेयर जावा में शामिल हों|हार्डवेयर जावा में सम्मिलित हों]] लैंग्वेज को आगे बढ़ाया हार्डवेयर शब्दार्थ को लागू करने के लिए ज्वाइन जावा। इस लैंग्वेज ने ज्वाइन जावा के शब्दार्थ को [[FPGA|एफपीजीए]] अनुप्रयोगों तक विस्तारित किया। | ||
== संदर्भ == | == संदर्भ == |
Latest revision as of 13:13, 26 October 2023
Paradigm | Procedural, Reflective |
---|---|
द्वारा डिज़ाइन किया गया | G. Stewart von Itzstein |
पहली प्रस्तुति | 2000 |
वेबसाइट | joinjava.unisa.edu.au |
Influenced by | |
Java |
ज्वाइन जावा एक प्रोग्रामिंग लैंग्वेज है जो सम्मिलित-पैटर्न पर आधारित है जो जोड़-गणना के ज्वाइन शब्दार्थ के साथ मानक जावा का विस्तार करती है। यह दक्षिण ऑस्ट्रेलिया विश्वविद्यालय में डॉ. वॉन इट्ज़स्टीन द्वारा रीकॉन्फिगरेबल कंप्यूटिंग लैब के भीतर लिखा गया था।
लैंग्वेज की विशेषताएं
ज्वाइन जावा विस्तारण तीन नए लैंग्वेज निर्माणों का परिचय देता है:
- ज्वाइन के तरीके
- एसिंक्रोनस तरीके
- पैटर्न के मिलान के क्रम को निर्धारित करने के लिए वर्ग संशोधक का क्रम निर्धारित करें
सबसे लोकप्रिय प्रोग्रामिंग लैंग्वेज में संगामिति को सेमाफोर और मॉनिटर जैसे निर्माणों का उपयोग करके कार्यान्वित किया जाता है। लाइब्रेरीज बन रहे हैं (जैसे जावा संगामिति लाइब्रेरीज जेएसआर-166) जो उच्च-स्तरीय संगामिति शब्दार्थ प्रदान करते हैं। संचार अनुक्रमिक प्रक्रियाओं (सीएसपी), संचार प्रणाली की गणना (सीसीएस) और पीआई में समवर्ती प्रक्रियाओं के अंतरापृष्ठ पर घटनाओं की संरचना के माध्यम से स्पष्ट रूप से परिभाषित उच्च-स्तरीय समकालीन व्यवहार होते हैं। इसके विपरीत, ज्वाइन गणना में, कमी नियमों के रूप में परिभाषित घटनाओं के स्थानीय संयोजन के आधार पर स्पष्ट समकालीन है। जोड़ना शब्दार्थ प्रक्रियाओं और चैनलों के गतिशील निर्माण और विनाश सहित मॉड्यूलर के वस्तु-उन्मुख विचार को भंग किए बिना समकालीन की स्पष्ट अभिव्यक्ति प्रदान करने का प्रयास करते हैं।
ज्वाइन जावा लैंग्वेज वस्तुतः सभी प्रकाशित समवर्ती पैटर्न को निम्न-स्तरीय मॉनिटर कॉल के लिए स्पष्ट सहारा के बिना व्यक्त कर सकती है। सामान्य तौर पर, जावा प्रोग्राम में सम्मिलित हों उनके जावा समकक्षों की तुलना में अधिक संक्षिप्त हैं। ज्वाइन जावा में प्रारम्भ किए गए अतिरिक्त को ज्वाइन कैलकुलस से प्राप्त उच्च-स्तरीय अभिव्यक्तियों द्वारा प्रबंधित किया जा सकता है। मॉनिटर (प्रतीक्षा करें और सूचित करें) से जुड़े समकालीन एक्सप्रेशन जो सामान्य रूप से मेथड के निकाय में स्थित होते हैं, उन्हें ज्वाइन जावा अभिव्यक्ति (ज्वाइन तरीकों) से बदला जा सकता है जो तरीका हस्ताक्षर का हिस्सा बनते हैं।
ज्वाइन के तरीके
ज्वाइन तरीका को दो या अधिक ज्वाइन विभाग द्वारा परिभाषित किया जाता है। ज्वाइन तरीका के सभी अंशों को बुलाए जाने के बाद ज्वाइन तरीका निष्पादित होगी। यदि रिटर्न प्रकार एक मानक जावा प्रकार है तो अग्रलेख विभाग कॉल करने वाले को तब तक ब्लॉक करें जब तक कि ज्वाइन तरीका पूरा न हो जाए और तरीका निष्पादित न हो जाए। यदि रिटर्न टाइप सिग्नल टाइप का है तो अग्रणी विभाग तुरंत वापस आ जाएगा। सभी अनुगामी विभाग हैं एसिंक्रोनस इसलिए कॉल करने वाले को ब्लॉक नहीं करेगा।
उदाहरण:
class JoinExample {
int fragment1() & fragment2(int x) {
//will return value of x
//to caller of fragment1
return x;
}
}
आर्डरएड मॉडीफिएर
ज्वाइन टुकड़े को विभिन्न ज्वाइन पैटर्न में दोहराया जा सकता है इसलिए ऐसा मामला हो सकता है जब टुकड़े को बुलाए जाने पर कई ज्वाइन वाले पैटर्न पूरा हो जाए। ऐसा मामला नीचे दिए गए उदाहरण में हो सकता है यदि बी (), सी () और डी () तो ए () कहा जाता हैं। अंतिम ए () विभाग तीन तरीका को पूरा करता है इसलिए तीन संभावित तरीके जिन्हें कहा जा सकता है। आर्डरएड क्लास मॉडीफिएर का उपयोग यह निर्धारित करने के लिए किया जाता है कि कौन सी ज्वाइन तरीका कहलाएगी। ऑनआर्डरएड क्लास मॉडीफिएर का उपयोग करते समय अनियमित रूप से मेथड में से एक को चुनना है। आर्डरएड मॉडीफिएर के साथ मेथड को घोषित किए गए क्रम के अनुसार प्राथमिकता दी जाती है।
उदाहरण:
class ordered SimpleJoinPattern {
void A() & B() {
}
void A() & C() {
}
void A() & D() {
}
signal D() & E() {
}
}
एसिंक्रोनस मेथड
एसिंक्रोनस मेथड को सिग्नल रिटर्न प्रकार का उपयोग करके परिभाषित किया जाता है। इसमें शून्य प्रकार के समान विशेषताएं हैं सिवाय इसके कि तरीका तुरंत वापस आ जाएगी। जब एसिंक्रोनस तरीके के बॉडी को निष्पादित करने के लिए नया क्रम बनाया जाता है।
उदाहरण:
class ThreadExample {
signal thread(SomeObject x) {
//this code will execute in a new thread
}
}
संबंधित भाषाएँ
पॉलीफोनिक सी शार्प निकटतम संबंधित लैंग्वेज है।
सीω पॉलीफोनिक सी शार्प का उत्तराधिकारी है।
हार्डवेयर जावा में सम्मिलित हों लैंग्वेज को आगे बढ़ाया हार्डवेयर शब्दार्थ को लागू करने के लिए ज्वाइन जावा। इस लैंग्वेज ने ज्वाइन जावा के शब्दार्थ को एफपीजीए अनुप्रयोगों तक विस्तारित किया।
संदर्भ
- von Itzstein, G, Stewart. and Jasiunas, M (2003). On Implementing High Level Concurrency in Java. Advances in Computer Systems Architecture 2003, Aizu Japan, Springer Verlag.
- von Itzstein, G, Stewart. and D. Kearney (2002). Applications of Join Java. Proceedings of the Seventh Asia Pacific Computer Systems Architecture Conference ACSAC'2002. Melbourne, Australia, Australian Computer Society: 1-20.
- von Itzstein, G, Stewart. and D. Kearney (2004). The Expression of Common Concurrency Patterns in Join Java. International Conference on Parallel and Distributed Processing Techniques and Applications, Las Vegas.
- Hopf, J., von Itzstein, G, Stewart, et al. (2002). Hardware Join Java: A High Level Language For Reconfigurable Hardware Development. International Conference on Field Programmable Technology, Hong Kong.