LISP - ऑपरेटर्स
एक ऑपरेटर एक प्रतीक है जो संकलक को विशिष्ट गणितीय या तार्किक जोड़तोड़ करने के लिए कहता है। LISP विभिन्न कार्यों, मैक्रोज़ और अन्य निर्माणों द्वारा समर्थित डेटा पर कई कार्यों की अनुमति देता है।
डेटा पर दिए गए कार्यों को इस प्रकार वर्गीकृत किया जा सकता है -
- अंकगणितीय आपरेशनस
- तुलना संचालन
- तार्किक संचालन
- बिटवाइज ऑपरेशन
अंकगणितीय आपरेशनस
निम्न तालिका LISP द्वारा समर्थित सभी अंकगणितीय ऑपरेटरों को दिखाती है। चर मान लेंA 10 और चर रखता है B 20 तब रखती है -
Show Examples
ऑपरेटर | विवरण | उदाहरण |
---|---|---|
+ | दो ऑपरेंड जोड़ता है | (+ AB) 30 देगा |
- | पहले से दूसरे ऑपरेंड को घटाता है | (- एबी) -10 देगा |
* | दोनों ऑपरेंड को गुणा करता है | (* AB) 200 देगा |
/ | डी-न्यूमेरियर द्वारा डिवाइडर को विभाजित करता है | (/ BA) 2 देगा |
आधुनिक, रेम | मापांक ऑपरेटर और पूर्णांक विभाजन के बाद शेष | (mod BA) 0 देगा |
INCF | वृद्धि ऑपरेटर निर्दिष्ट किए गए दूसरे तर्क द्वारा पूर्णांक मान बढ़ाता है | (incf A 3) 13 देंगे |
DECF | Decrements ऑपरेटर निर्दिष्ट किए गए दूसरे तर्क द्वारा पूर्णांक मान घटाता है | (decf A 4) 9 देंगे |
तुलना संचालन
निम्नलिखित तालिका LISP द्वारा समर्थित सभी रिलेशनल ऑपरेटरों को दर्शाती है जो संख्याओं के बीच तुलना करते हैं। हालांकि, अन्य भाषाओं में संबंधपरक ऑपरेटरों के विपरीत, LISP तुलना ऑपरेटर दो से अधिक ऑपरेंड ले सकते हैं और वे केवल संख्याओं पर काम करते हैं।
चर मान लें A 10 और चर रखता है B 20 रखती है, तो -
Show Examples
ऑपरेटर | विवरण | उदाहरण |
---|---|---|
= | जाँच करता है कि क्या ऑपरेंड के मान सभी समान हैं या नहीं, यदि हाँ तो स्थिति सच हो जाती है। | (= AB) सत्य नहीं है। |
/ = | जाँच करता है कि क्या संचालकों के मूल्य अलग-अलग हैं या नहीं, यदि मान समान नहीं हैं तो स्थिति सत्य हो जाती है। | (/ = AB) सत्य है। |
> | जाँच करता है कि क्या ऑपरेंड्स का मान नीरस रूप से कम हो रहा है। | (> एबी) सच नहीं है। |
< | जाँच करता है कि क्या ऑपरेंड का मान नीरस रूप से बढ़ रहा है। | (<AB) सत्य है। |
> = | जाँच करता है कि क्या किसी बाएँ संकार्य का मान अगले दाहिने संकार्य के मान से अधिक या उसके बराबर है, यदि हाँ तो स्थिति सत्य हो जाती है। | (> = एबी) सत्य नहीं है। |
<= | जाँच करता है कि क्या किसी भी बाएं ऑपरेंड का मूल्य उसके सही ऑपरेंड के मूल्य से कम या उसके बराबर है, यदि हाँ, तो स्थिति सच हो जाती है। | (<= AB) सत्य है। |
मैक्स | यह दो या अधिक तर्कों की तुलना करता है और अधिकतम मूल्य लौटाता है। | (अधिकतम AB) २० देता है |
मिनट | यह दो या अधिक तर्कों की तुलना करता है और न्यूनतम मूल्य लौटाता है। | (न्यूनतम एबी) १० देता है |
बूलियन मूल्यों पर तार्किक संचालन
आम LISP तीन तार्किक ऑपरेटर प्रदान करता है: and, or, तथा notजो बूलियन मूल्यों पर संचालित होता है। मान लीजियेA मूल्य शून्य है और B मान 5 है, तो -
Show Examples
ऑपरेटर | विवरण | उदाहरण |
---|---|---|
तथा | यह किसी भी प्रकार की बहस करता है। तर्कों का मूल्यांकन बाएँ से दाएँ किया जाता है। यदि सभी तर्क गैर-शून्य का मूल्यांकन करते हैं, तो अंतिम तर्क का मूल्य वापस आ जाता है। अन्यथा नील वापस आ जाता है। | (और एबी) एनआईएल लौटाएगा। |
या | यह किसी भी प्रकार की बहस करता है। तर्कों का मूल्यांकन तब तक दाएं से बाएं किया जाता है जब तक कि कोई गैर-शून्य का मूल्यांकन नहीं करता है, ऐसे मामले में तर्क मान लौटाया जाता है, अन्यथा यह वापस आ जाता हैnil। | (या AB) 5 लौटाएगा। |
नहीं | यह एक तर्क और रिटर्न लेता है t यदि तर्क का मूल्यांकन करता है nil. | (A नहीं) T वापस आएगा। |
नंबरों पर बिटवाइज ऑपरेशन
बिटवाइज़ ऑपरेटर बिट पर काम करते हैं और बिट-बाय-बिट ऑपरेशन करते हैं। बिटवाइज़ और, या, और संचालन के लिए सत्य सारणी इस प्रकार हैं -
Show Examples
पी | क्यू | पी और क्यू | पोर क्ष | p xor क्ष |
---|---|---|---|---|
0 | 0 | 0 | 0 | 0 |
0 | 1 | 0 | 1 | 1 |
1 | 1 | 1 | 1 | 0 |
1 | 0 | 0 | 1 | 1 |
Assume if A = 60; and B = 13; now in binary format they will be as follows:
A = 0011 1100
B = 0000 1101
-----------------
A and B = 0000 1100
A or B = 0011 1101
A xor B = 0011 0001
not A = 1100 0011
LISP द्वारा समर्थित बिटवाइज़ ऑपरेटर निम्न तालिका में सूचीबद्ध हैं। चर मान लेंA 60 और चर रखता है B 13 रखती है, तो -
ऑपरेटर | विवरण | उदाहरण |
---|---|---|
logand | यह थोड़ा-सा तार्किक और उसके तर्कों का प्रतिफल देता है। यदि कोई तर्क नहीं दिया जाता है, तो परिणाम -1 है, जो इस ऑपरेशन के लिए एक पहचान है। | (logand ab)) 12 देगा |
logior | यह बिट-वार तार्किक INCLUSIVE या इसके तर्कों की वापसी करता है। यदि कोई तर्क नहीं दिया जाता है, तो परिणाम शून्य है, जो इस ऑपरेशन के लिए एक पहचान है। | (logior ab) 61 देगा |
logxor | यह बिट-वार तार्किक EXCLUSIVE या इसके तर्कों का प्रतिफल देता है। यदि कोई तर्क नहीं दिया जाता है, तो परिणाम शून्य है, जो इस ऑपरेशन के लिए एक पहचान है। | (logxor ab) 49 देगा |
lognor | यह अपने तर्कों के बिट-वार नहीं लौटाता है। यदि कोई तर्क नहीं दिया जाता है, तो परिणाम -1 है, जो इस ऑपरेशन के लिए एक पहचान है। | (लोगनोर अब) -62 देंगे, |
logeqv | यह अपने तर्कों के अनुसार बिट-लॉजिकल इक्विवल (विशेष रूप से और न ही) के रूप में जाना जाता है। यदि कोई तर्क नहीं दिया जाता है, तो परिणाम -1 है, जो इस ऑपरेशन के लिए एक पहचान है। | (logeqv ab) देगा -50 |