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