पास्कल - संचालक
एक ऑपरेटर एक प्रतीक है जो संकलक को विशिष्ट गणितीय या तार्किक जोड़तोड़ करने के लिए कहता है। पास्कल ऑपरेटरों के निम्नलिखित प्रकारों की अनुमति देता है -
- अंकगणितीय आपरेटर
- संबंधपरक संकारक
- बूलियन ऑपरेटर्स
- बिट संचालक
- ऑपरेटर सेट करें
- स्ट्रिंग ऑपरेटरों
आइए हम एक-एक करके अंकगणित, संबंधपरक, बूलियन और बिट ऑपरेटरों पर चर्चा करें। हम बाद में सेट ऑपरेटरों और स्ट्रिंग संचालन पर चर्चा करेंगे।
अंकगणितीय आपरेटर
निम्नलिखित तालिका पास्कल द्वारा समर्थित सभी अंकगणितीय ऑपरेटरों को दर्शाती है। चर मान लेंA 10 और चर रखता है B 20 रखती है, तो -
उदाहरण दिखाएं
ऑपरेटर | विवरण | उदाहरण |
---|---|---|
+ | दो ऑपरेंड जोड़ता है | A + B 30 देगा |
- | पहले से दूसरे ऑपरेंड को घटाता है | A - B देगा -10 |
* | दोनों ऑपरेंड को गुणा करता है | A * B 200 देगा |
/ | भाजक द्वारा अंश को विभाजित करता है | B / A 2 देगा |
% | मापांक ऑपरेटर और पूर्णांक विभाजन के बाद शेष | ब% ए द 0 दे खोगे |
संबंधपरक संकारक
निम्नलिखित तालिका पास्कल द्वारा समर्थित सभी रिलेशनल ऑपरेटरों को दिखाती है। चर मान लेंA 10 और चर रखता है B 20 रखती है, तो -
उदाहरण दिखाएं
ऑपरेटर | विवरण | उदाहरण |
---|---|---|
= | जाँच करता है कि दो ऑपरेंड के मान समान हैं या नहीं, यदि हाँ, तो स्थिति सच हो जाती है। | (ए = बी) सच नहीं है। |
<> | जाँच करता है कि दो ऑपरेंड के मान समान हैं या नहीं, यदि मान समान नहीं हैं, तो स्थिति सत्य हो जाती है। | (ए <> बी) सच है। |
> | जाँच करता है कि क्या बाएं संकार्य का मान दाहिने संचालक के मान से अधिक है, यदि हाँ, तो स्थिति सत्य हो जाती है। | (ए> बी) सच नहीं है। |
< | जाँच करता है कि क्या बाएं ऑपरेंड का मूल्य सही ऑपरेंड के मूल्य से कम है, यदि हाँ, तो स्थिति सच हो जाती है। | (ए <बी) सच है। |
> = | जाँच करता है कि क्या बाएं ऑपरेंड का मूल्य सही ऑपरेंड के मूल्य से अधिक या बराबर है, यदि हाँ, तो स्थिति सच हो जाती है। | (ए> = बी) सच नहीं है। |
<= | जाँच करता है कि क्या बाएं ऑपरेंड का मूल्य सही ऑपरेंड के मूल्य से कम या बराबर है, यदि हाँ, तो स्थिति सच हो जाती है। | (ए <= बी) सच है। |
बूलियन ऑपरेटर्स
निम्नलिखित तालिका पास्कल भाषा द्वारा समर्थित सभी बूलियन ऑपरेटरों को दिखाती है। ये सभी ऑपरेटर बूलियन ऑपरेंड पर काम करते हैं और बूलियन परिणाम उत्पन्न करते हैं। चर मान लेंA सत्य और परिवर्तनशील है B गलत है, तो -
उदाहरण दिखाएं
ऑपरेटर | विवरण | उदाहरण |
---|---|---|
तथा | जिसे बुलियन एंड ऑपरेटर कहा जाता है। यदि दोनों ऑपरेंड सच हैं, तो स्थिति सच हो जाती है। | (ए और बी) गलत है। |
और फिर | यह एंड ऑपरेटर के समान है, हालांकि, यह उस क्रम की गारंटी देता है जिसमें कंपाइलर तार्किक अभिव्यक्ति का मूल्यांकन करता है। बाएं से दाएं और दाएं ऑपरेंड का मूल्यांकन केवल आवश्यक होने पर किया जाता है। | (ए और फिर बी) गलत है। |
या | जिसे बूलियन या ऑपरेटर कहा जाता है। यदि दोनों संचालनों में से कोई भी सत्य है, तो स्थिति सत्य हो जाती है। | (ए या बी) सच है। |
वरना | यह बूलियन या के समान है, हालांकि, यह उस क्रम की गारंटी देता है जिसमें संकलक तार्किक अभिव्यक्ति का मूल्यांकन करता है। बाएं से दाएं और दाएं ऑपरेंड का मूल्यांकन केवल आवश्यक होने पर किया जाता है। | (ए या फिर बी) सच है। |
नहीं | जिसे बुलियन नॉट ऑपरेटर कहा जाता है। अपने ऑपरेंड की तार्किक स्थिति को उलट देता था। यदि कोई शर्त सत्य है, तो लॉजिकल नॉट ऑपरेटर इसे गलत बना देगा। | नहीं (ए और बी) सच है। |
बिट संचालक
बिटवाइज़ ऑपरेटर बिट पर काम करते हैं और बिट-बाय-बिट ऑपरेशन करते हैं। ये सभी ऑपरेटर पूर्णांक ऑपरेंड पर काम करते हैं और पूर्णांक परिणाम तैयार करते हैं। बिटवाइज़ और (()), बिटवाइज़ या (!) के लिए सत्य तालिका, और बिटवाइज़ नहीं (~) इस प्रकार हैं -
पी | क्यू | पी क्यू | पी | क्यू | ~ पी | ~ क्ष |
---|---|---|---|---|---|
0 | 0 | 0 | 0 | 1 | 1 |
0 | 1 | 0 | 1 | 1 | 0 |
1 | 1 | 1 | 1 | 0 | 0 |
1 | 0 | 0 | 1 | 0 | 1 |
मान लें कि ए = 60; और बी = 13; अब द्विआधारी प्रारूप में वे निम्नानुसार होंगे -
ए = 0011 1100
B = 0000 1101
-----------------
A & B = 0000 1100
ए ^ बी = 0011 0001
~ ए = ११०० ००११
पास्कल द्वारा समर्थित बिटवाइज़ ऑपरेटरों को निम्न तालिका में सूचीबद्ध किया गया है। चर ए मान लें 60 और चर बी 13 रखता है, तो:
उदाहरण दिखाएं
ऑपरेटर | विवरण | उदाहरण |
---|---|---|
और | बाइनरी और ऑपरेटर परिणाम के लिए थोड़ा सा कॉपी करता है यदि यह दोनों ऑपरेंड में मौजूद है। | (A & B) 12 देगा, जो 0000 1100 है |
| | बाइनरी या ऑपरेटर थोड़ा सा कॉपी करता है अगर यह किसी भी ऑपरेंड में मौजूद है। | (ए | बी) 61 देगा, जो 0011 1101 है |
! | बाइनरी या ऑपरेटर थोड़ा सा कॉपी करता है अगर यह किसी भी ऑपरेंड में मौजूद है। इसके समान | ऑपरेटर। | (ए! बी) 61 देगा, जो 0011 1101 है |
~ | बाइनरी ओन्स कंप्लीट ऑपरेटर, एकात्मक है और इसमें 'फ्लिपिंग' बिट्स का प्रभाव है। | (~ ए) -61 देगा, जो कि हस्ताक्षरित बाइनरी नंबर के कारण 2 के पूरक रूप में 1100 0011 है। |
<< | बाइनरी लेफ्ट शिफ्ट ऑपरेटर। बाएं ऑपरेंड वैल्यू को दाएं ऑपरेंड द्वारा निर्दिष्ट बिट्स की संख्या से छोड़ दिया जाता है। | A << 2 240 देगा, जो कि 1111 0000 है |
>> | बाइनरी राइट शिफ्ट ऑपरेटर। बाएं ऑपरेंड वैल्यू को दाएं ऑपरेंड द्वारा निर्दिष्ट बिट्स की संख्या से दाएं स्थानांतरित किया जाता है। | A >> 2 15 देगा, जो 0000 1111 है |
कृपया ध्यान दें कि पास्कल के विभिन्न कार्यान्वयन बिटवाइज़ ऑपरेटरों में भिन्न हैं। पास्कल, कंपाइलर जिसका हमने यहां उपयोग किया था, हालांकि, निम्नलिखित बिटवाइज़ ऑपरेटरों का समर्थन करता है -
ऑपरेटर्स | संचालन |
---|---|
नहीं | बिटवाइज़ नहीं |
तथा | बिटवाइज़ और |
या | बिटवार या |
XOR | बिटवाइज़ एक्सक्लूसिव OR |
shl | बिटवाइज़ शिफ्ट छोड़ दिया |
SHR | बिटवाइस शिफ्ट सही |
<< | बिटवाइज़ शिफ्ट छोड़ दिया |
>> | बिटवाइस शिफ्ट सही |
पास्कल में ऑपरेटरों की प्रक्रिया
ऑपरेटर पूर्वता एक अभिव्यक्ति में शब्दों के समूहीकरण को निर्धारित करती है। यह प्रभावित करता है कि एक अभिव्यक्ति का मूल्यांकन कैसे किया जाता है। कुछ ऑपरेटरों में अन्य लोगों की तुलना में अधिक पूर्वता है; उदाहरण के लिए, गुणा ऑपरेटर में अतिरिक्त ऑपरेटर की तुलना में अधिक पूर्वता है।
उदाहरण के लिए x = 7 + 3 * 2; यहाँ, x को 13 नहीं, 20 को सौंपा गया है क्योंकि ऑपरेटर * में + से अधिक पूर्वता है, इसलिए यह पहले 3 * 2 के साथ गुणा हो जाता है और फिर 7 में जुड़ जाता है।
यहां, सबसे अधिक पूर्वता वाले ऑपरेटर तालिका के शीर्ष पर दिखाई देते हैं, सबसे नीचे वाले लोग सबसे नीचे दिखाई देते हैं। एक अभिव्यक्ति के भीतर, उच्च पूर्वता ऑपरेटरों का मूल्यांकन पहले किया जाएगा।
उदाहरण दिखाएं
ऑपरेटर | प्रधानता |
---|---|
~, नहीं, | उच्चतम |
*, /, div, मॉड, और | |
|;;, +, -, या, | |
=, <>, <, <=>,> =, में | |
या फिर, और फिर | सबसे कम |