LISP - त्वरित गाइड
जॉन मैकार्थी ने फोरट्रान के विकास के तुरंत बाद 1958 में LISP का आविष्कार किया। यह पहली बार आईबीएम 704 कंप्यूटर पर स्टीव रसेल द्वारा लागू किया गया था।
यह आर्टिफिशियल इंटेलिजेंस कार्यक्रमों के लिए विशेष रूप से उपयुक्त है, क्योंकि यह प्रतीकात्मक जानकारी को प्रभावी ढंग से संसाधित करता है।
आम लिस्प की उत्पत्ति 1980 और 1990 के दशक के दौरान हुई, कई कार्यान्वयन समूहों के काम को एक करने के प्रयास में, जो मैक्लिस्प के उत्तराधिकारी थे, जैसे कि ZetaLisp और NIL (लिस्प का नया कार्यान्वयन) आदि।
यह एक सामान्य भाषा के रूप में कार्य करती है, जिसे विशिष्ट कार्यान्वयन के लिए आसानी से बढ़ाया जा सकता है।
कॉमन LISP में लिखे गए प्रोग्राम मशीन-विशिष्ट विशेषताओं पर निर्भर नहीं करते हैं, जैसे शब्द की लंबाई आदि।
आम एलआईएसपी की विशेषताएं
यह मशीन-स्वतंत्र है
यह पुनरावृत्ति डिजाइन पद्धति, और आसान एक्स्टेंसिबिलिटी का उपयोग करता है।
यह गतिशील रूप से कार्यक्रमों को अपडेट करने की अनुमति देता है।
यह उच्च स्तरीय डिबगिंग प्रदान करता है।
यह उन्नत वस्तु-उन्मुख प्रोग्रामिंग प्रदान करता है।
यह एक सुविधाजनक मैक्रो सिस्टम प्रदान करता है।
यह वस्तुओं, संरचनाओं, सूचियों, वैक्टर, समायोज्य सरणियों, हैश-टेबल और प्रतीकों जैसे व्यापक डेटा प्रकार प्रदान करता है।
यह अभिव्यक्ति-आधारित है।
यह एक वस्तु-उन्मुख स्थिति प्रणाली प्रदान करता है।
यह एक पूर्ण I / O पुस्तकालय प्रदान करता है।
यह व्यापक नियंत्रण संरचना प्रदान करता है।
LISP में निर्मित अनुप्रयोग
लिस्प में निर्मित बड़े सफल अनुप्रयोग।
Emacs
G2
AutoCad
इगोर एनग्रेवर
याहू स्टोर
स्थानीय पर्यावरण सेटअप
यदि आप अभी भी लिस्प प्रोग्रामिंग भाषा के लिए अपना वातावरण सेट करने के लिए तैयार हैं, तो आपको अपने कंप्यूटर पर उपलब्ध दो सॉफ्टवेयर्स की आवश्यकता है, (ए) टेक्स्ट एडिटर और (बी) द लिस्प एक्सक्यूटर।
पाठ संपादक
इसका उपयोग आपके प्रोग्राम को टाइप करने के लिए किया जाएगा। कुछ संपादकों के उदाहरणों में विंडोज नोटपैड, ओएस एडिट कमांड, ब्रीफ, एप्सिलॉन, ईएमएसीएस और विम या vi शामिल हैं।
टेक्स्ट एडिटर का नाम और संस्करण अलग-अलग ऑपरेटिंग सिस्टम पर भिन्न हो सकते हैं। उदाहरण के लिए, नोटपैड का उपयोग विंडोज पर किया जाएगा, और vim या vi का उपयोग विंडोज़ के साथ-साथ लिनक्स या यूनिक्स पर भी किया जा सकता है।
आपके द्वारा अपने संपादक के साथ बनाई गई फाइलों को सोर्स फाइल कहा जाता है और इसमें प्रोग्राम सोर्स कोड होता है। लिस्प कार्यक्रमों के लिए स्रोत फ़ाइलों को आमतौर पर एक्सटेंशन के साथ नामित किया जाता है ".lisp"।
अपनी प्रोग्रामिंग शुरू करने से पहले, सुनिश्चित करें कि आपके पास एक पाठ संपादक है और आपके पास एक कंप्यूटर प्रोग्राम लिखने के लिए पर्याप्त अनुभव है, इसे एक फ़ाइल में सहेजें, अंत में इसे निष्पादित करें।
लिस्प एक्सक्यूटर
स्रोत फ़ाइल में लिखा गया स्रोत कोड आपके प्रोग्राम के लिए मानव पठनीय स्रोत है। इसे "निष्पादित" करने की आवश्यकता है, मशीन भाषा में बदलने के लिए ताकि आपका सीपीयू वास्तव में दिए गए निर्देशों के अनुसार कार्यक्रम को निष्पादित कर सके।
इस लिस्प प्रोग्रामिंग भाषा का उपयोग आपके स्रोत कोड को अंतिम निष्पादन कार्यक्रम में निष्पादित करने के लिए किया जाएगा। मुझे लगता है कि आपको प्रोग्रामिंग भाषा के बारे में बुनियादी जानकारी है।
सीएलआईएसपी जीएनयू कॉमन एलआईएसपी मल्टी-आर्किटेकट्रेल कंपाइलर है जिसका उपयोग विंडोज में एलआईएसपी की स्थापना के लिए किया जाता है। विंडोज़ संस्करण विंडोज़ के तहत मिंगडब्ल्यू का उपयोग करके एक यूनिक्स वातावरण का अनुकरण करता है। इंस्टॉलर इस बात का ध्यान रखता है और स्वचालित रूप से विंडोज़ पथ चर में क्लिष्ट जोड़ता है।
आप यहाँ से विंडोज के लिए नवीनतम CLISP प्राप्त कर सकते हैं - https://sourceforge.net/projects/clisp/files/latest/download
यह लाइन-बाय-लाइन दुभाषिया के लिए डिफ़ॉल्ट रूप से स्टार्ट मेनू में एक शॉर्टकट बनाता है।
CLISP का उपयोग कैसे करें
इंस्टॉलेशन के दौरान, clisp यदि आप विकल्प (RECOMMENDED) का चयन करते हैं तो स्वचालित रूप से आपके PATH चर में जोड़ा जाता है। इसका मतलब है कि आप बस एक नया कमांड प्रॉम्प्ट विंडो खोल सकते हैं और कंपाइलर लाने के लिए "clisp" टाइप कर सकते हैं।
* .Lisp या * .lsp फ़ाइल चलाने के लिए, बस उपयोग करें -
clisp hello.lisp
एलआईएसपी अभिव्यक्तियों को प्रतीकात्मक अभिव्यक्ति या एस-एक्सप्रेशन कहा जाता है। एस-भाव तीन वैध वस्तुओं, परमाणुओं, सूचियों और तारों से बना है।
कोई भी एस-एक्सप्रेशन एक वैध कार्यक्रम है।
LISP प्रोग्राम या तो a पर चलते हैं interpreter या के रूप में compiled code.
दुभाषिया एक दोहराया लूप में स्रोत कोड की जांच करता है, जिसे रीड-मूल्यांकन-प्रिंट लूप (REPL) भी कहा जाता है। यह प्रोग्राम कोड पढ़ता है, इसका मूल्यांकन करता है, और प्रोग्राम द्वारा लौटाए गए मानों को प्रिंट करता है।
एक साधारण कार्यक्रम
आइए हम तीन संख्याओं 7, 9 और 11. का योग ज्ञात करने के लिए एक एस-एक्सप्रेशन लिखते हैं। ऐसा करने के लिए, हम दुभाषिया प्रॉम्प्ट पर टाइप कर सकते हैं।
(+ 7 9 11)
LISP ने लौटाया रिजल्ट -
27
यदि आप एक ही प्रोग्राम को संकलित कोड के रूप में चलाना चाहते हैं, तो myprog.lisp नाम से एक LISP स्रोत कोड फ़ाइल बनाएं और उसमें निम्न कोड टाइप करें।
(write (+ 7 9 11))
जब आप Execute बटन पर क्लिक करते हैं, या Ctrl + E टाइप करते हैं, तो LISP इसे तुरंत निष्पादित करता है और वापस लौटा परिणाम है -
27
LISP उपसर्ग संकेतन का उपयोग करता है
आपने देखा होगा कि LISP उपयोग करता है prefix notation.
उपरोक्त प्रोग्राम में + सिंबल संख्याओं के योग की प्रक्रिया के लिए फ़ंक्शन नाम के रूप में काम करता है।
उपसर्ग संकेतन में, ऑपरेटरों को उनके ऑपरेंड से पहले लिखा जाता है। उदाहरण के लिए, अभिव्यक्ति,
a * ( b + c ) / d
के रूप में लिखा जाएगा -
(/ (* a (+ b c) ) d)
आइए एक और उदाहरण लेते हैं, आइए हम 60 डिग्री फेरनहाइट के फ़ारेनहाइट टेम्प को सेंटिग्रेड पैमाने पर लिखने के लिए कोड लिखते हैं -
इस रूपांतरण की गणितीय अभिव्यक्ति होगी -
(60 * 9 / 5) + 32
एक सोर्स कोड फाइल बनाएं जिसका नाम main.lisp है और इसमें निम्न कोड टाइप करें।
(write(+ (* (/ 9 5) 60) 32))
जब आप Execute बटन पर क्लिक करते हैं, या Ctrl + E टाइप करते हैं, तो LISP इसे तुरंत निष्पादित करता है और परिणाम is− लौटाता है
140
एलआईएसपी कार्यक्रमों का मूल्यांकन
LISP कार्यक्रमों के मूल्यांकन के दो भाग हैं -
एक पाठक कार्यक्रम द्वारा लिस्प वस्तुओं में कार्यक्रम पाठ का अनुवाद
एक मूल्यांकनकर्ता कार्यक्रम द्वारा इन वस्तुओं के संदर्भ में भाषा के शब्दार्थ का कार्यान्वयन
मूल्यांकन प्रक्रिया में निम्न चरण होते हैं -
पाठक पात्रों के तार को LISP ऑब्जेक्ट्स में अनुवादित करता है या s-expressions.
मूल्यांकनकर्ता लिस्प के सिंटैक्स को परिभाषित करता है formsजो कि एस-एक्सप्रेशन से बनाए गए हैं। मूल्यांकन का यह दूसरा स्तर एक सिंटैक्स को परिभाषित करता है जो निर्धारित करता हैs-expressions LISP फॉर्म हैं।
मूल्यांकनकर्ता एक फ़ंक्शन के रूप में काम करता है जो एक तर्क के रूप में एक वैध LISP फॉर्म लेता है और एक मूल्य देता है। यही कारण है कि हम LISP अभिव्यक्ति को कोष्ठक में रखते हैं, क्योंकि हम मूल्यांकन करने वाले को तर्क के साथ पूरी अभिव्यक्ति / फॉर्म भेज रहे हैं।
'हैलो वर्ल्ड' कार्यक्रम
एक नई प्रोग्रामिंग भाषा सीखना वास्तव में तब तक नहीं होता है जब तक आप यह नहीं सीखते कि उस भाषा में पूरी दुनिया को शुभकामनाएं कैसे दें!
तो, कृपया main.lisp नाम से नया सोर्स कोड फ़ाइल बनाएं और उसमें निम्न कोड टाइप करें।
(write-line "Hello World")
(write-line "I am at 'Tutorials Point'! Learning LISP")
जब आप Execute बटन पर क्लिक करते हैं, या Ctrl + E टाइप करते हैं, तो LISP इसे तुरंत निष्पादित करता है और वापस लौटा परिणाम है -
Hello World
I am at 'Tutorials Point'! Learning LISP
LISP में बेसिक बिल्डिंग ब्लॉक
LISP कार्यक्रम तीन बुनियादी भवन ब्लॉकों से बने होते हैं -
- atom
- list
- string
एक atomसन्निहित वर्णों की एक संख्या या स्ट्रिंग है। इसमें संख्या और विशेष वर्ण शामिल हैं।
निम्नलिखित कुछ मान्य परमाणुओं के उदाहरण हैं -
hello-from-tutorials-point
name
123008907
*hello*
Block#221
abc123
ए list कोष्ठकों में संलग्न परमाणुओं और / या अन्य सूचियों का एक क्रम है।
कुछ मान्य सूचियों के उदाहरण निम्नलिखित हैं -
( i am a list)
(a ( a b c) d e fgh)
(father tom ( susan bill joe))
(sun mon tue wed thur fri sat)
( )
ए string दोहरे उद्धरण चिह्नों में संलग्न वर्णों का एक समूह है।
कुछ मान्य तार के उदाहरण निम्नलिखित हैं -
" I am a string"
"a ba c d efg #$%^&!"
"Please enter the following details :"
"Hello from 'Tutorials Point'! "
टिप्पणियाँ जोड़ना
सेमीकॉलन प्रतीक (?) का उपयोग टिप्पणी लाइन को इंगित करने के लिए किया जाता है।
उदाहरण के लिए,
(write-line "Hello World") ; greet the world
; tell them your whereabouts
(write-line "I am at 'Tutorials Point'! Learning LISP")
जब आप Execute बटन पर क्लिक करते हैं, या Ctrl + E टाइप करते हैं, तो LISP इसे तुरंत निष्पादित करता है और वापस लौटा परिणाम है -
Hello World
I am at 'Tutorials Point'! Learning LISP
आगे बढ़ने से पहले कुछ उल्लेखनीय बिंदु
नोट करने के लिए कुछ महत्वपूर्ण बिंदु निम्नलिखित हैं -
LISP में मूल संख्यात्मक ऑपरेशन +, -, *, और / हैं
LISP एक फ़ंक्शन कॉल f (x) as (fx) का प्रतिनिधित्व करता है, उदाहरण के लिए cos (45) को cos 45 लिखा जाता है
LISP एक्सप्रेशन केस-असंवेदनशील हैं, cos 45 या COS 45 समान हैं।
LISP एक फ़ंक्शन के तर्कों सहित सब कुछ का मूल्यांकन करने की कोशिश करता है। केवल तीन प्रकार के तत्व निरंतर हैं और हमेशा अपने स्वयं के मूल्य वापस करते हैं
Numbers
पत्र t, यह तार्किक सत्य के लिए खड़ा है।
महत्व nil, यह तार्किक झूठ के साथ-साथ एक खाली सूची के लिए भी खड़ा है।
LISP फॉर्म के बारे में थोड़ा अधिक
पिछले अध्याय में, हमने उल्लेख किया है कि LISP कोड की मूल्यांकन प्रक्रिया में निम्न चरण होते हैं।
पाठक पात्रों के तार को LISP ऑब्जेक्ट्स में अनुवादित करता है या s-expressions.
मूल्यांकनकर्ता लिस्प के सिंटैक्स को परिभाषित करता है formsजो कि एस-एक्सप्रेशन से बनाए गए हैं। मूल्यांकन का यह दूसरा स्तर एक सिंटैक्स को परिभाषित करता है जो यह निर्धारित करता है कि कौन से एस-अभिव्यक्ति एलआईएसपी रूप हैं।
अब, एक LISP फॉर्म हो सकता है।
- एक परमाणु
- एक खाली या गैर-सूची
- कोई भी सूची जिसमें पहले तत्व के रूप में एक प्रतीक है
मूल्यांकनकर्ता एक फ़ंक्शन के रूप में काम करता है जो एक तर्क के रूप में एक वैध LISP फॉर्म लेता है और एक मूल्य देता है। यही कारण है कि हम डाल दियाLISP expression in parenthesis, क्योंकि हम मूल्यांकनकर्ता को तर्क के रूप में पूरी अभिव्यक्ति / फॉर्म भेज रहे हैं।
LISP में नामकरण परंपराएँ
नाम या प्रतीकों में व्हॉट्सएप, ओपन एंड क्लोजिंग कोष्ठक, डबल और सिंगल कोट्स, बैकस्लैश, अल्पविराम, कोलोन, सेमीकोलन और वर्टिकल बार के अलावा किसी भी प्रकार के अल्फ़ान्यूमेरिक वर्ण शामिल हो सकते हैं। एक नाम में इन वर्णों का उपयोग करने के लिए, आपको भागने चरित्र (\) का उपयोग करने की आवश्यकता है।
एक नाम में अंक हो सकते हैं लेकिन पूरी तरह से अंकों से नहीं बने होते हैं, क्योंकि तब इसे एक संख्या के रूप में पढ़ा जाएगा। इसी तरह एक नाम में अवधि हो सकती है, लेकिन पूरी तरह से अवधि नहीं बनाई जा सकती है।
सिंगल कोटेशन मार्क का उपयोग
LISP फ़ंक्शन तर्कों और सूची सदस्यों सहित सब कुछ का मूल्यांकन करता है।
कभी-कभी, हमें परमाणुओं या सूचियों को शाब्दिक रूप से लेने की आवश्यकता होती है और वे फ़ंक्शन कॉल के रूप में मूल्यांकन या इलाज नहीं चाहते हैं।
ऐसा करने के लिए, हमें परमाणु या सूची को एक उद्धरण चिह्न के साथ पूर्ववर्ती करने की आवश्यकता है।
निम्न उदाहरण यह प्रदर्शित करता है।
Main.lisp नाम की एक फाइल बनाएं और उसमें निम्न कोड टाइप करें।
(write-line "single quote used, it inhibits evaluation")
(write '(* 2 3))
(write-line " ")
(write-line "single quote not used, so expression evaluated")
(write (* 2 3))
जब आप Execute बटन पर क्लिक करते हैं, या Ctrl + E टाइप करते हैं, तो LISP इसे तुरंत निष्पादित करता है और वापस लौटा परिणाम है -
single quote used, it inhibits evaluation
(* 2 3)
single quote not used, so expression evaluated
6
LISP में, चर टाइप नहीं किए जाते हैं, लेकिन डेटा ऑब्जेक्ट हैं।
LISP डेटा प्रकारों को वर्गीकृत किया जा सकता है।
Scalar types - उदाहरण के लिए, संख्या प्रकार, वर्ण, प्रतीक आदि।
Data structures - उदाहरण के लिए, सूचियाँ, वैक्टर, बिट-वैक्टर और तार।
कोई भी चर किसी भी LISP वस्तु को उसके मूल्य के रूप में ले सकता है, जब तक कि आपने इसे स्पष्ट रूप से घोषित नहीं किया है।
यद्यपि, एलआईएसपी चर के लिए डेटा प्रकार निर्दिष्ट करना आवश्यक नहीं है, हालांकि, यह कुछ लूप विस्तार, विधि घोषणाओं और कुछ अन्य स्थितियों में मदद करता है, जिनके बारे में हम बाद के अध्यायों में चर्चा करेंगे।
डेटा प्रकार एक पदानुक्रम में व्यवस्थित होते हैं। एक डेटा प्रकार LISP ऑब्जेक्ट का एक सेट है और कई ऑब्जेक्ट एक ऐसे सेट से संबंधित हो सकते हैं।
typep विधेय का उपयोग यह खोजने के लिए किया जाता है कि कोई वस्तु किसी विशिष्ट प्रकार की है या नहीं।
type-of फ़ंक्शन किसी दिए गए ऑब्जेक्ट का डेटा प्रकार लौटाता है।
LISP में टाइप स्पेशलिस्ट
प्रकार विनिर्देशक डेटा प्रकारों के लिए सिस्टम-परिभाषित प्रतीक हैं।
सरणी | fixnum | पैकेज | सरल-स्ट्रिंग |
परमाणु | नाव | पथ नाम | सरल-वेक्टर |
bignum | समारोह | यादृच्छिक राज्य | एकल नाव |
बिट | हैश टेबल | अनुपात | मानक-चार |
बिट वेक्टर | पूर्णांक | युक्तिसंगत | धारा |
चरित्र | कीवर्ड | readtable | तार |
[सामान्य] | सूची | अनुक्रम | [स्ट्रिंग-चार] |
संकलित-समारोह | लंबी नाव | शॉर्ट नाव | प्रतीक |
जटिल | nill | पर हस्ताक्षर किए-बाइट | टी |
विपक्ष | शून्य | सरल सरणी | अहस्ताक्षरित बाइट |
डबल नाव | संख्या | सरल-बिट-वेक्टर | वेक्टर |
इन सिस्टम-परिभाषित प्रकारों के अलावा, आप अपने स्वयं के डेटा प्रकार बना सकते हैं। जब एक संरचना प्रकार का उपयोग करके परिभाषित किया जाता हैdefstruct फ़ंक्शन, संरचना प्रकार का नाम एक मान्य प्रकार का प्रतीक बन जाता है।
उदाहरण 1
Main.lisp नाम से नया सोर्स कोड फ़ाइल बनाएं और उसमें निम्न कोड टाइप करें।
(setq x 10)
(setq y 34.567)
(setq ch nil)
(setq n 123.78)
(setq bg 11.0e+4)
(setq r 124/2)
(print x)
(print y)
(print n)
(print ch)
(print bg)
(print r)
जब आप Execute बटन पर क्लिक करते हैं, या Ctrl + E टाइप करते हैं, तो LISP इसे तुरंत निष्पादित करता है और वापस लौटा परिणाम है -
10
34.567
123.78
NIL
110000.0
62
उदाहरण 2
अगला चलो पिछले उदाहरण में उपयोग किए गए चर के प्रकारों की जांच करते हैं। मुख्य नाम की नई स्रोत कोड फ़ाइल बनाएँ। लिस्प और इसमें निम्न कोड टाइप करें।
(defvar x 10)
(defvar y 34.567)
(defvar ch nil)
(defvar n 123.78)
(defvar bg 11.0e+4)
(defvar r 124/2)
(print (type-of x))
(print (type-of y))
(print (type-of n))
(print (type-of ch))
(print (type-of bg))
(print (type-of r))
जब आप Execute बटन पर क्लिक करते हैं, या Ctrl + E टाइप करते हैं, तो LISP इसे तुरंत निष्पादित करता है और वापस लौटा परिणाम है -
(INTEGER 0 281474976710655)
SINGLE-FLOAT
SINGLE-FLOAT
NULL
SINGLE-FLOAT
(INTEGER 0 281474976710655)
मैक्रोज़ आपको मानक LISP के सिंटैक्स का विस्तार करने की अनुमति देते हैं।
तकनीकी रूप से, एक मैक्रो एक ऐसा फ़ंक्शन है जो तर्क के रूप में एक एस-एक्सप्रेशन लेता है और एक एलआईएसपी फॉर्म लौटाता है, जो तब मूल्यांकन किया जाता है।
मैक्रो को परिभाषित करना
LISP में, एक नामित मैक्रो को किसी अन्य मैक्रो नाम का उपयोग करके परिभाषित किया गया है defmacro. स्थूल को परिभाषित करने का सिंटैक्स है -
(defmacro macro-name (parameter-list))
"Optional documentation string."
body-form
मैक्रो परिभाषा में मैक्रो, एक पैरामीटर सूची, एक वैकल्पिक दस्तावेज़ीकरण स्ट्रिंग, और लिस्प अभिव्यक्तियों का एक निकाय शामिल है जो मैक्रो द्वारा निष्पादित की जाने वाली नौकरी को परिभाषित करता है।
उदाहरण
आइए हम setTo10 नाम का एक सरल मैक्रो लिखते हैं, जो एक संख्या लेगा और उसका मान 10 पर सेट करेगा।
Main.lisp नाम से नया सोर्स कोड फ़ाइल बनाएं और उसमें निम्न कोड टाइप करें।
(defmacro setTo10(num)
(setq num 10)(print num))
(setq x 25)
(print x)
(setTo10 x)
जब आप Execute बटन पर क्लिक करते हैं, या Ctrl + E टाइप करते हैं, तो LISP इसे तुरंत निष्पादित करता है और वापस लौटा परिणाम है -
25
10
LISP में, प्रत्येक चर का प्रतिनिधित्व a symbol। चर का नाम प्रतीक का नाम है और इसे प्रतीक के भंडारण कक्ष में संग्रहीत किया जाता है।
सार्वत्रिक चर
वैश्विक चर पूरे LISP सिस्टम में स्थायी मान रखते हैं और एक नया मूल्य निर्दिष्ट होने तक प्रभावी रहते हैं।
वैश्विक चर को आम तौर पर उपयोग करते हुए घोषित किया जाता है defvar निर्माण।
उदाहरण के लिए
(defvar x 234)
(write x)
जब आप Execute बटन पर क्लिक करते हैं, या Ctrl + E टाइप करते हैं, तो LISP इसे तुरंत निष्पादित करता है और वापस लौटा परिणाम होता है
234
चूंकि LISP में चर के लिए कोई प्रकार की घोषणा नहीं है, आप सीधे एक प्रतीक के लिए एक मान निर्दिष्ट करते हैं setq निर्माण।
उदाहरण के लिए
->(setq x 10)
उपरोक्त अभिव्यक्ति वैरिएबल x को मान 10 प्रदान करती है। आप एक अभिव्यक्ति के रूप में प्रतीक का उपयोग करके चर का उल्लेख कर सकते हैं।
symbol-value फ़ंक्शन आपको प्रतीक भंडारण स्थान पर संग्रहीत मान निकालने की अनुमति देता है।
उदाहरण के लिए
Main.lisp नाम से नया सोर्स कोड फ़ाइल बनाएं और उसमें निम्न कोड टाइप करें।
(setq x 10)
(setq y 20)
(format t "x = ~2d y = ~2d ~%" x y)
(setq x 100)
(setq y 200)
(format t "x = ~2d y = ~2d" x y)
जब आप Execute बटन पर क्लिक करते हैं, या Ctrl + E टाइप करते हैं, तो LISP इसे तुरंत निष्पादित करता है और वापस लौटा परिणाम होता है।
x = 10 y = 20
x = 100 y = 200
स्थानीय चर
स्थानीय चर किसी निर्धारित प्रक्रिया के भीतर परिभाषित किए जाते हैं। फ़ंक्शन परिभाषा के भीतर तर्क के रूप में नामित पैरामीटर भी स्थानीय चर हैं। स्थानीय चर संबंधित फ़ंक्शन के भीतर ही सुलभ हैं।
वैश्विक चरों की तरह, स्थानीय चरों का उपयोग करके भी बनाया जा सकता है setq निर्माण।
दो अन्य निर्माण हैं - let तथा prog स्थानीय चर बनाने के लिए।
लेट कंस्ट्रक्शन में निम्नलिखित सिंटैक्स होता है।
(let ((var1 val1) (var2 val2).. (varn valn))<s-expressions>)
जहाँ var1, var2, ..vn वैरिएबल नाम और val1, val2, .. वैलेन संबंधित वैरिएबल को दिए गए प्रारंभिक मान हैं।
कब letनिष्पादित किया जाता है, प्रत्येक चर को संबंधित मान सौंपा जाता है और अंतिम रूप से एस-अभिव्यक्ति का मूल्यांकन किया जाता है। मूल्यांकन की गई अंतिम अभिव्यक्ति का मूल्य वापस आ गया है।
यदि आप एक चर के लिए एक प्रारंभिक मूल्य शामिल नहीं करते हैं, तो इसे सौंपा गया है nil.
उदाहरण
Main.lisp नाम से नया सोर्स कोड फ़ाइल बनाएं और उसमें निम्न कोड टाइप करें।
(let ((x 'a) (y 'b)(z 'c))
(format t "x = ~a y = ~a z = ~a" x y z))
जब आप Execute बटन पर क्लिक करते हैं, या Ctrl + E टाइप करते हैं, तो LISP इसे तुरंत निष्पादित करता है और वापस लौटा परिणाम होता है।
x = A y = B z = C
prog निर्माण में इसके पहले तर्क के रूप में स्थानीय चर की सूची भी होती है, जिसका अनुसरण निकाय द्वारा किया जाता है prog, और किसी भी संख्या में एस-भाव।
prog फ़ंक्शन अनुक्रम में एस-अभिव्यक्तियों की सूची को निष्पादित करता है और शून्य वापस करता है जब तक कि यह एक फ़ंक्शन कॉल का नाम नहीं देता है return. तब का तर्क return फ़ंक्शन का मूल्यांकन किया जाता है और वापस आ जाता है।
उदाहरण
Main.lisp नाम से नया सोर्स कोड फ़ाइल बनाएं और उसमें निम्न कोड टाइप करें।
(prog ((x '(a b c))(y '(1 2 3))(z '(p q 10)))
(format t "x = ~a y = ~a z = ~a" x y z))
जब आप Execute बटन पर क्लिक करते हैं, या Ctrl + E टाइप करते हैं, तो LISP इसे तुरंत निष्पादित करता है और वापस लौटा परिणाम होता है।
x = (A B C) y = (1 2 3) z = (P Q 10)
LISP में, स्थिरांक वे चर होते हैं जो प्रोग्राम निष्पादन के दौरान अपने मूल्यों को कभी नहीं बदलते हैं। का उपयोग करते हुए लगातार घोषित किए जाते हैंdefconstant निर्माण।
उदाहरण
निम्न उदाहरण एक वैश्विक स्थिर पीआई की घोषणा करता है और बाद में एक सर्कल के क्षेत्र की गणना करने वाले क्षेत्र -सर्कल नामक फ़ंक्शन के अंदर इस मूल्य का उपयोग करता है।
defun किसी फ़ंक्शन को परिभाषित करने के लिए निर्माण का उपयोग किया जाता है, हम इसमें देखेंगे Functions अध्याय।
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(defconstant PI 3.141592)
(defun area-circle(rad)
(terpri)
(format t "Radius: ~5f" rad)
(format t "~%Area: ~10f" (* PI rad rad)))
(area-circle 10)
जब आप Execute बटन पर क्लिक करते हैं, या Ctrl + E टाइप करते हैं, तो LISP इसे तुरंत निष्पादित करता है और वापस लौटा परिणाम होता है।
Radius: 10.0
Area: 314.1592
एक ऑपरेटर एक प्रतीक है जो संकलक को विशिष्ट गणितीय या तार्किक जोड़तोड़ करने के लिए कहता है। LISP विभिन्न कार्यों, मैक्रोज़ और अन्य निर्माणों द्वारा समर्थित डेटा पर कई कार्यों की अनुमति देता है।
डेटा पर दिए गए ऑपरेशनों को वर्गीकृत किया जा सकता है -
- अंकगणितीय आपरेशनस
- तुलना संचालन
- तार्किक संचालन
- बिटवाइज ऑपरेशन
अंकगणितीय आपरेशनस
निम्न तालिका LISP द्वारा समर्थित सभी अंकगणितीय ऑपरेटरों को दिखाती है। चर मान लेंA 10 और चर रखता है B 20 तब रखती है -
Show Examples
ऑपरेटर | विवरण | उदाहरण |
---|---|---|
+ | दो ऑपरेंड जोड़ता है | (+ एबी) 30 देगा |
- | पहले से दूसरे ऑपरेंड को घटाता है | (- एबी) -10 देगा |
* | दोनों ऑपरेंड को गुणा करता है | (* AB) 200 देगा |
/ | डी-न्यूमेरियर द्वारा अंशों को विभाजित करता है | (/ बीए) 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 है, जो इस ऑपरेशन के लिए एक पहचान है। | (lognor ab) देगा -62, |
logeqv | यह अपने तर्कों के अनुसार बिट-लॉजिकल इक्विवल (विशेष रूप से और न ही) के रूप में जाना जाता है। यदि कोई तर्क नहीं दिया जाता है, तो परिणाम -1 है, जो इस ऑपरेशन के लिए एक पहचान है। | (logeqv ab) -50 देगा |
निर्णय लेने की संरचनाओं के लिए आवश्यक है कि प्रोग्रामर एक या एक से अधिक शर्तों को प्रोग्राम द्वारा मूल्यांकन या परीक्षण करने के लिए निर्दिष्ट करे, साथ ही एक स्टेटमेंट या स्टेटमेंट के साथ निष्पादित किया जाए यदि शर्त सही हो, और वैकल्पिक रूप से, अन्य स्टेटमेंट्स को निष्पादित किया जाए, यदि कंडीशन हो झूठा होना तय है।
अधिकांश प्रोग्रामिंग भाषाओं में पाया जाने वाला एक विशिष्ट निर्णय लेने की संरचना का सामान्य रूप निम्नलिखित है -
एलआईएसपी निम्नलिखित प्रकार के निर्णय लेने वाले निर्माण प्रदान करता है। उनके विवरण की जाँच करने के लिए निम्न लिंक पर क्लिक करें।
अनु क्रमांक। | निर्माण और विवरण |
---|---|
1 | cond यह निर्माण कई परीक्षण-कार्रवाई खंडों की जाँच के लिए उपयोग किया जाता है। इसकी तुलना नेस्टेड से की जा सकती है यदि अन्य प्रोग्रामिंग भाषाओं में स्टेटमेंट। |
2 | अगर यदि निर्माण के विभिन्न रूप हैं। सबसे सरल रूप में यह एक परीक्षण खंड, एक परीक्षण कार्रवाई और कुछ अन्य परिणामी कार्रवाई (ओं) द्वारा पीछा किया जाता है। यदि परीक्षण खंड सत्य का मूल्यांकन करता है, तो परीक्षण कार्रवाई को निष्पादित किया जाता है, अन्यथा परिणामी खंड का मूल्यांकन किया जाता है। |
3 | कब सबसे सरल रूप में यह एक परीक्षण खंड, और एक परीक्षण कार्रवाई द्वारा पीछा किया जाता है। यदि परीक्षण खंड सत्य का मूल्यांकन करता है, तो परीक्षण कार्रवाई को निष्पादित किया जाता है, अन्यथा परिणामी खंड का मूल्यांकन किया जाता है। |
4 | मामला यह कंस्ट्रक्शन की तरह कई टेस्ट-एक्शन क्लॉस को लागू करता है। हालाँकि, यह एक मुख्य रूप का मूल्यांकन करता है और उस कुंजी रूप के मूल्यांकन के आधार पर कई क्रिया खंडों की अनुमति देता है। |
एक स्थिति हो सकती है, जब आपको कई बार कोड संख्याओं के ब्लॉक को निष्पादित करने की आवश्यकता होती है। एक लूप स्टेटमेंट हमें कई बार किसी स्टेटमेंट या स्टेटमेंट ऑफ स्टेटमेंट को निष्पादित करने की अनुमति देता है और अधिकांश प्रोग्रामिंग भाषाओं में लूप स्टेटमेंट का सामान्य रूप है।
LISP लूपिंग आवश्यकताओं को संभालने के लिए निम्न प्रकार के निर्माण प्रदान करता है। उनके विवरण की जाँच करने के लिए निम्न लिंक पर क्लिक करें।
अनु क्रमांक। | निर्माण और विवरण |
---|---|
1 | लूप loopनिर्माण LISP द्वारा प्रदान की गई पुनरावृत्ति का सबसे सरल रूप है। अपने सरलतम रूप में, यह आपको कुछ स्टेटमेंट्स को बार-बार निष्पादित करने की अनुमति देता है जब तक कि यह एक नहीं मिलता हैreturn बयान। |
2 | के लिए पाश निर्माण के लिए लूप आपको अन्य भाषाओं में सबसे आम के रूप में पुनरावृत्ति की तरह लागू करने की अनुमति देता है। |
3 | कर Do निर्माण का उपयोग LISP का उपयोग करके प्रदर्शन करने के लिए भी किया जाता है। यह पुनरावृत्ति का एक संरचित रूप प्रदान करता है। |
4 | dotimes Dotimes निर्माण कुछ निश्चित संख्या में पुनरावृत्तियों के लिए लूपिंग की अनुमति देता है। |
5 | सूची करो डोलिस्ट निर्माण सूची के प्रत्येक तत्व के माध्यम से पुनरावृत्ति की अनुमति देता है। |
एक ब्लॉक से शानदार तरीके से बाहर निकलना
block तथा return-from आप किसी भी त्रुटि के मामले में किसी भी नेस्टेड ब्लॉक से इनायत से बाहर निकलने की अनुमति देता है।
blockफ़ंक्शन आपको शून्य या अधिक कथनों से बना निकाय के साथ एक नामित ब्लॉक बनाने की अनुमति देता है। सिंटेक्स है -
(block block-name(
...
...
))
return-from फ़ंक्शन एक ब्लॉक नाम लेता है और एक वैकल्पिक (डिफ़ॉल्ट शून्य होता है) रिटर्न वैल्यू।
निम्न उदाहरण यह प्रदर्शित करता है -
उदाहरण
Main.lisp नाम से एक नया स्रोत कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें -
(defun demo-function (flag)
(print 'entering-outer-block)
(block outer-block
(print 'entering-inner-block)
(print (block inner-block
(if flag
(return-from outer-block 3)
(return-from inner-block 5)
)
(print 'This-wil--not-be-printed))
)
(print 'left-inner-block)
(print 'leaving-outer-block)
t)
)
(demo-function t)
(terpri)
(demo-function nil)
जब आप Execute बटन पर क्लिक करते हैं, या Ctrl + E टाइप करते हैं, तो LISP इसे तुरंत निष्पादित करता है और वापस लौटा परिणाम है -
ENTERING-OUTER-BLOCK
ENTERING-INNER-BLOCK
ENTERING-OUTER-BLOCK
ENTERING-INNER-BLOCK
5
LEFT-INNER-BLOCK
LEAVING-OUTER-BLOCK
एक फ़ंक्शन एक कथन का एक समूह है जो एक साथ एक कार्य करता है।
आप अपने कोड को अलग-अलग कार्यों में विभाजित कर सकते हैं। आप अलग-अलग कार्यों के बीच अपने कोड को कैसे विभाजित करते हैं, यह आपके ऊपर है, लेकिन तार्किक रूप से विभाजन आमतौर पर प्रत्येक फ़ंक्शन एक विशिष्ट कार्य करता है।
LISP में कार्य को परिभाषित करना
स्थूल नाम का defunका उपयोग कार्यों को परिभाषित करने के लिए किया जाता है। defun स्थूल को तीन तर्क चाहिए -
- समारोह का नाम
- फ़ंक्शन के पैरामीटर
- समारोह का अंग
डिफॉन के लिए सिंटैक्स है -
(defun name (parameter-list) "Optional documentation string." body)
आइए हम सरल उदाहरणों के साथ अवधारणा का वर्णन करें।
उदाहरण 1
आइए एक फ़ंक्शन लिखें जिसका नाम है एवरेजेनम जो चार संख्याओं के औसत को प्रिंट करेगा। हम इन नंबरों को पैरामीटर के रूप में भेजेंगे।
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(defun averagenum (n1 n2 n3 n4)
(/ ( + n1 n2 n3 n4) 4)
)
(write(averagenum 10 20 30 40))
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
25
उदाहरण 2
आइए एक फ़ंक्शन को परिभाषित करें और कॉल करें जो सर्कल के क्षेत्र की गणना करेगा जब सर्कल के त्रिज्या को एक तर्क के रूप में दिया जाता है।
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(defun area-circle(rad)
"Calculates area of a circle with given radius"
(terpri)
(format t "Radius: ~5f" rad)
(format t "~%Area: ~10f" (* 3.141592 rad rad))
)
(area-circle 10)
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
Radius: 10.0
Area: 314.1592
कृपया ध्यान दें कि -
आप एक खाली सूची को पैरामीटर के रूप में प्रदान कर सकते हैं, जिसका अर्थ है कि फ़ंक्शन कोई तर्क नहीं लेता है, सूची खाली है, जिसे () लिखा गया है।
LISP वैकल्पिक, एकाधिक और कीवर्ड तर्क भी देता है।
प्रलेखन स्ट्रिंग फ़ंक्शन के उद्देश्य का वर्णन करता है। यह फ़ंक्शन के नाम से जुड़ा हुआ है और इसका उपयोग करके प्राप्त किया जा सकता हैdocumentation समारोह।
फ़ंक्शन के शरीर में लिस्प अभिव्यक्तियों की किसी भी संख्या शामिल हो सकती है।
शरीर में अंतिम अभिव्यक्ति का मान फ़ंक्शन के मान के रूप में लौटाया जाता है।
आप फ़ंक्शन का उपयोग करके भी मान लौटा सकते हैं return-from विशेष संचालक।
आइए हम उपरोक्त अवधारणाओं पर संक्षेप में चर्चा करें। विवरण पाने के लिए नीचे दिए गए लिंक पर क्लिक करें -
वैकल्पिक पैरामीटर
बाकी पैरामीटर
कीवर्ड पैरामीटर्स
एक समारोह से मान लौटाना
लंबोदर कार्य
मानचित्रण कार्य
विधेय ऐसे कार्य हैं जो कुछ विशिष्ट स्थितियों के लिए अपने तर्कों का परीक्षण करते हैं और यदि स्थिति झूठी है, या कुछ गैर-शून्य मान है तो स्थिति सत्य है।
निम्न तालिका कुछ सबसे अधिक इस्तेमाल की जाने वाली भविष्यवाणी को दिखाती है -
अनु क्रमांक। | समर्पित करें और विवरण दें |
---|---|
1 | atom यह एक तर्क लेता है और यदि तर्क एक परमाणु या शून्य है तो अन्यथा वापस आ जाता है। |
2 | equal इसमें दो तर्क और रिटर्न लगते हैं t यदि वे संरचनात्मक रूप से समान हैं या nil अन्यथा। |
3 | eq इसमें दो तर्क और रिटर्न लगते हैं t यदि वे एक ही समान ऑब्जेक्ट हैं, तो समान मेमोरी लोकेशन साझा करना या nil अन्यथा। |
4 | eql इसमें दो तर्क और रिटर्न लगते हैं t यदि तर्क हैं eq, या यदि वे एक ही मूल्य के साथ एक ही प्रकार के नंबर हैं, या यदि वे चरित्र ऑब्जेक्ट हैं जो एक ही चरित्र का प्रतिनिधित्व करते हैं, या nil अन्यथा। |
5 | evenp यह एक संख्यात्मक तर्क और रिटर्न लेता है t यदि तर्क संख्या या है nil यदि अन्यथा। |
6 | oddp यह एक संख्यात्मक तर्क और रिटर्न लेता है t यदि तर्क विषम संख्या है या nil यदि अन्यथा। |
7 | zerop यह एक संख्यात्मक तर्क और रिटर्न लेता है t यदि तर्क शून्य है या nil यदि अन्यथा। |
8 | null यह एक तर्क और रिटर्न लेता है t यदि तर्क शून्य का मूल्यांकन करता है, अन्यथा यह वापस आ जाता है nil। |
9 | listp यह एक तर्क और रिटर्न लेता है t यदि तर्क किसी सूची का मूल्यांकन करता है तो वह वापस आ जाता है nil। |
10 | greaterp यह एक या अधिक तर्क लेता है और रिटर्न करता है t यदि या तो एक ही तर्क है या तर्क क्रमिक रूप से बाएं से दाएं बड़ा है, या nil यदि अन्यथा। |
1 1 | lessp यह एक या अधिक तर्क लेता है और रिटर्न करता है t यदि या तो कोई तर्क है या तर्क क्रमिक रूप से बाएं से दाएं छोटे हैं, या nil यदि अन्यथा। |
12 | numberp यह एक तर्क और रिटर्न लेता है t यदि तर्क एक संख्या है या nil यदि अन्यथा। |
13 | symbolp यह एक तर्क और रिटर्न लेता है t यदि तर्क एक प्रतीक है अन्यथा यह वापस आ जाता है nil। |
14 | integerp यह एक तर्क और रिटर्न लेता है t यदि तर्क पूर्णांक है, तो यह वापस आ जाता है nil। |
15 | rationalp यह एक तर्क और रिटर्न लेता है t यदि तर्क तर्कसंगत संख्या है, तो अनुपात या संख्या, अन्यथा यह वापस आ जाती है nil। |
16 | floatp यह एक तर्क और रिटर्न लेता है t यदि तर्क एक अस्थायी बिंदु संख्या है अन्यथा यह वापस आ जाता है nil। |
17 | realp यह एक तर्क और रिटर्न लेता है t यदि तर्क एक वास्तविक संख्या है अन्यथा यह वापस आ जाता है nil। |
18 | complexp यह एक तर्क और रिटर्न लेता है t यदि तर्क एक जटिल संख्या है अन्यथा यह वापस आ जाती है nil. |
19 | characterp यह एक तर्क और रिटर्न लेता है t यदि तर्क एक चरित्र है अन्यथा यह वापस आ जाता है nil। |
20 | stringp यह एक तर्क और रिटर्न लेता है t यदि तर्क एक स्ट्रिंग ऑब्जेक्ट है अन्यथा यह वापस आ जाता है nil। |
21 | arrayp यह एक तर्क और रिटर्न लेता है t अगर तर्क एक सरणी वस्तु है अन्यथा यह वापस आ जाता है nil। |
22 | packagep यह एक तर्क और रिटर्न लेता है t यदि तर्क एक पैकेज है अन्यथा यह वापस आ जाता है nil. |
उदाहरण 1
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(write (atom 'abcd))
(terpri)
(write (equal 'a 'b))
(terpri)
(write (evenp 10))
(terpri)
(write (evenp 7 ))
(terpri)
(write (oddp 7 ))
(terpri)
(write (zerop 0.0000000001))
(terpri)
(write (eq 3 3.0 ))
(terpri)
(write (equal 3 3.0 ))
(terpri)
(write (null nil ))
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
T
NIL
T
NIL
T
NIL
NIL
NIL
T
उदाहरण 2
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(defun factorial (num)
(cond ((zerop num) 1)
(t ( * num (factorial (- num 1))))
)
)
(setq n 6)
(format t "~% Factorial ~d is: ~d" n (factorial n))
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
Factorial 6 is: 720
आम लिस्प कई प्रकार की संख्याओं को परिभाषित करता है। number डेटा प्रकार में LISP द्वारा समर्थित विभिन्न प्रकार की संख्याएँ शामिल हैं।
LISP द्वारा समर्थित संख्या प्रकार हैं -
- Integers
- Ratios
- दशमलव संख्याएं
- जटिल आंकड़े
निम्नलिखित चित्र संख्या पदानुक्रम और LISP में उपलब्ध विभिन्न संख्यात्मक प्रकारों को दर्शाता है -
LISP में विभिन्न संख्यात्मक प्रकार
निम्न तालिका LISP में उपलब्ध विभिन्न प्रकार के डेटा का वर्णन करती है -
अनु क्रमांक। | डेटा प्रकार और विवरण |
---|---|
1 | fixnum यह डेटा प्रकार पूर्णांक का प्रतिनिधित्व करता है जो बहुत बड़े नहीं होते हैं और अधिकतर -215 से 215-1 की सीमा में होते हैं (यह मशीन पर निर्भर है) |
2 | bignum ये एलआईएसपी के लिए आवंटित स्मृति की मात्रा द्वारा सीमित आकार के साथ बहुत बड़ी संख्या हैं, वे फिक्सनम संख्या नहीं हैं। |
3 | ratio अंश / भाजक रूप में दो संख्याओं के अनुपात का प्रतिनिधित्व करता है। / फ़ंक्शन हमेशा अनुपात में परिणाम उत्पन्न करता है, जब इसके तर्क पूर्णांक होते हैं। |
4 | float यह गैर-पूर्णांक संख्याओं का प्रतिनिधित्व करता है। बढ़ती सटीकता के साथ चार फ्लोट डेटा प्रकार हैं। |
5 | complex यह जटिल संख्याओं का प्रतिनिधित्व करता है, जिन्हें #c द्वारा दर्शाया जाता है। वास्तविक और काल्पनिक दोनों भाग तर्कसंगत या फ्लोटिंग पॉइंट संख्या हो सकते हैं। |
उदाहरण
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(write (/ 1 2))
(terpri)
(write ( + (/ 1 2) (/ 3 4)))
(terpri)
(write ( + #c( 1 2) #c( 3 -4)))
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
1/2
5/4
#C(4 -2)
संख्या कार्य
निम्न तालिका कुछ सामान्य रूप से उपयोग किए जाने वाले संख्यात्मक कार्यों का वर्णन करती है -
अनु क्रमांक। | समारोह विवरण |
---|---|
1 | +, -, *, / प्रतिक्रियाशील अंकगणितीय संचालन |
2 | sin, cos, tan, acos, asin, atan प्रतिक्रियाशील त्रिकोणमितीय कार्य। |
3 | sinh, cosh, tanh, acosh, asinh, atanh प्रतिक्रियाशील अतिशयोक्तिपूर्ण कार्य। |
4 | exp घातांक कार्य करते हैं। ई x की गणना करता है |
5 | expt एक्सपेंसेशन फंक्शन, बेस और पावर दोनों लेता है। |
6 | sqrt यह एक संख्या के वर्गमूल की गणना करता है। |
7 | log लघुगणक समारोह। यह एक पैरामीटर दिया जाता है, फिर यह इसके प्राकृतिक लघुगणक की गणना करता है, अन्यथा दूसरे पैरामीटर का उपयोग आधार के रूप में किया जाता है। |
8 | conjugate यह एक संख्या के जटिल संयुग्म की गणना करता है। वास्तविक संख्या के मामले में, यह संख्या को ही वापस करता है। |
9 | abs यह किसी संख्या का पूर्ण मान (या परिमाण) लौटाता है। |
10 | gcd यह दी गई संख्याओं के सबसे बड़े सामान्य भाजक की गणना करता है। |
1 1 | lcm यह दी गई संख्याओं के कम से कम सामान्य गुणकों की गणना करता है। |
12 | isqrt यह किसी दिए गए प्राकृतिक संख्या के सटीक वर्गमूल से कम या उसके बराबर सबसे बड़ा पूर्णांक देता है। |
13 | floor, ceiling, truncate, round ये सभी कार्य दो तर्कों को एक संख्या के रूप में लेते हैं और भागफल को लौटाते हैं; floor सबसे बड़ा पूर्णांक देता है जो अनुपात से अधिक नहीं है, ceiling छोटे पूर्णांक को चुनता है जो अनुपात से बड़ा है, truncate अनुपात के सबसे बड़े निरपेक्ष मान के साथ उसी चिन्ह के पूर्णांक को चुनता है जो अनुपात के निरपेक्ष मान से कम हो, और round एक पूर्णांक चुनता है जो अनुपात के सबसे करीब है। |
14 | ffloor, fceiling, ftruncate, fround उपरोक्त के समान ही है, लेकिन भागफल को फ्लोटिंग पॉइंट संख्या के रूप में लौटाता है। |
15 | mod, rem शेष को एक डिवीजन ऑपरेशन में लौटाता है। |
16 | float एक वास्तविक संख्या को एक अस्थायी बिंदु संख्या में परिवर्तित करता है। |
17 | rational, rationalize एक वास्तविक संख्या को तर्कसंगत संख्या में रूपांतरित करता है। |
18 | numerator, denominator एक परिमेय संख्या के संबंधित भागों को लौटाता है। |
19 | realpart, imagpart एक जटिल संख्या का वास्तविक और काल्पनिक हिस्सा लौटाता है। |
उदाहरण
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(write (/ 45 78))
(terpri)
(write (floor 45 78))
(terpri)
(write (/ 3456 75))
(terpri)
(write (floor 3456 75))
(terpri)
(write (ceiling 3456 75))
(terpri)
(write (truncate 3456 75))
(terpri)
(write (round 3456 75))
(terpri)
(write (ffloor 3456 75))
(terpri)
(write (fceiling 3456 75))
(terpri)
(write (ftruncate 3456 75))
(terpri)
(write (fround 3456 75))
(terpri)
(write (mod 3456 75))
(terpri)
(setq c (complex 6 7))
(write c)
(terpri)
(write (complex 5 -9))
(terpri)
(write (realpart c))
(terpri)
(write (imagpart c))
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
15/26
0
1152/25
46
47
46
46
46.0
47.0
46.0
46.0
6
#C(6 7)
#C(5 -9)
6
7
LISP में, वर्णों को डेटा ऑब्जेक्ट के प्रकार के रूप में दर्शाया जाता है character.
आप वर्ण से पहले # \ _ से पहले किसी वर्ण ऑब्जेक्ट को निरूपित कर सकते हैं। उदाहरण के लिए, # \ _ का मतलब चरित्र a है।
अंतरिक्ष और अन्य विशेष वर्णों को वर्ण के नाम से पहले # \ _ से दर्शाया जा सकता है। उदाहरण के लिए, # \ SPACE अंतरिक्ष वर्ण का प्रतिनिधित्व करता है।
निम्न उदाहरण यह प्रदर्शित करता है -
उदाहरण
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(write 'a)
(terpri)
(write #\a)
(terpri)
(write-char #\a)
(terpri)
(write-char 'a)
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
A
#\a
a
*** - WRITE-CHAR: argument A is not a character
विशेष वर्ण
सामान्य LISP आपके कोड में निम्नलिखित विशेष वर्णों का उपयोग करने की अनुमति देता है। उन्हें अर्ध-मानक वर्ण कहा जाता है।
- #\Backspace
- #\Tab
- #\Linefeed
- #\Page
- #\Return
- #\Rubout
चरित्र तुलना कार्य
संख्यात्मक तुलना फ़ंक्शंस और ऑपरेटर, जैसे, <और> वर्णों पर काम नहीं करते हैं। सामान्य LISP आपके कोड में वर्णों की तुलना करने के लिए अन्य दो कार्य प्रदान करता है।
एक सेट केस-संवेदी है और दूसरा केस-असंवेदनशील।
निम्न तालिका कार्य प्रदान करती है -
केस सेंसिटिव फंक्शंस | केस-असंवेदनशील कार्य | विवरण |
---|---|---|
चार = | चार-बराबर | जाँच करता है कि क्या ऑपरेंड के मान सभी समान हैं या नहीं, यदि हाँ तो स्थिति सच हो जाती है। |
चार / = | चार-नहीं-बराबर | जाँच करता है कि क्या संचालकों के मूल्य अलग-अलग हैं या नहीं, यदि मान समान नहीं हैं तो स्थिति सत्य हो जाती है। |
चार < | चार-lessp | जाँच करता है कि क्या ऑपरेंड का मान नीरस रूप से कम हो रहा है। |
चार> | चार-greaterp | जाँच करता है कि क्या ऑपरेंड का मान नीरस रूप से बढ़ रहा है। |
चार <= | चार-नहीं-greaterp | यह जांचता है कि क्या किसी भी बाएं संकार्य का मान अगले दाहिने संचालक के मान से अधिक या उसके बराबर है, यदि हाँ, तो स्थिति सत्य है। |
चार> = | चार-नहीं-lessp | यह जांचता है कि क्या किसी भी बाएं संकार्य का मूल्य उसके दाहिने संचालक के मूल्य से कम या उसके बराबर है, यदि हाँ तो स्थिति सत्य हो जाती है। |
उदाहरण
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
; case-sensitive comparison
(write (char= #\a #\b))
(terpri)
(write (char= #\a #\a))
(terpri)
(write (char= #\a #\A))
(terpri)
;case-insensitive comparision
(write (char-equal #\a #\A))
(terpri)
(write (char-equal #\a #\b))
(terpri)
(write (char-lessp #\a #\b #\c))
(terpri)
(write (char-greaterp #\a #\b #\c))
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
NIL
T
NIL
T
NIL
T
NIL
LISP आपको एकल या एकाधिक-आयाम सरणियों को परिभाषित करने की अनुमति देता है make-arrayसमारोह। एक सरणी किसी भी LISP ऑब्जेक्ट को उसके तत्वों के रूप में संग्रहीत कर सकती है।
सभी सरणियों में सन्निहित स्मृति स्थान शामिल हैं। निम्नतम पता पहले तत्व से मेल खाता है और उच्चतम पता अंतिम तत्व से।
किसी सरणी के आयामों की संख्या को इसकी रैंक कहा जाता है।
एलआईएसपी में, एक सरणी तत्व गैर-नकारात्मक पूर्णांक सूचकांकों के अनुक्रम द्वारा निर्दिष्ट किया जाता है। अनुक्रम की लंबाई को सरणी के रैंक के बराबर होना चाहिए। इंडेक्सिंग शून्य से शुरू होती है।
उदाहरण के लिए, 10- कोशिकाओं के साथ एक सरणी बनाने के लिए, मेरा नाम-सरणी, हम लिख सकते हैं -
(setf my-array (make-array '(10)))
Aref फ़ंक्शन कोशिकाओं की सामग्री तक पहुंचने की अनुमति देता है। यह दो तर्क लेता है, सरणी का नाम और सूचकांक मूल्य।
उदाहरण के लिए, दसवीं सेल की सामग्री तक पहुँचने के लिए, हम लिखते हैं -
(aref my-array 9)
उदाहरण 1
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(write (setf my-array (make-array '(10))))
(terpri)
(setf (aref my-array 0) 25)
(setf (aref my-array 1) 23)
(setf (aref my-array 2) 45)
(setf (aref my-array 3) 10)
(setf (aref my-array 4) 20)
(setf (aref my-array 5) 17)
(setf (aref my-array 6) 25)
(setf (aref my-array 7) 19)
(setf (aref my-array 8) 67)
(setf (aref my-array 9) 30)
(write my-array)
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
#(NIL NIL NIL NIL NIL NIL NIL NIL NIL NIL)
#(25 23 45 10 20 17 25 19 67 30)
उदाहरण 2
आइए हम एक 3-बाय -3 एरे बनाते हैं।
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(setf x (make-array '(3 3)
:initial-contents '((0 1 2 ) (3 4 5) (6 7 8)))
)
(write x)
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
#2A((0 1 2) (3 4 5) (6 7 8))
उदाहरण 3
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(setq a (make-array '(4 3)))
(dotimes (i 4)
(dotimes (j 3)
(setf (aref a i j) (list i 'x j '= (* i j)))
)
)
(dotimes (i 4)
(dotimes (j 3)
(print (aref a i j))
)
)
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
(0 X 0 = 0)
(0 X 1 = 0)
(0 X 2 = 0)
(1 X 0 = 0)
(1 X 1 = 1)
(1 X 2 = 2)
(2 X 0 = 0)
(2 X 1 = 2)
(2 X 2 = 4)
(3 X 0 = 0)
(3 X 1 = 3)
(3 X 2 = 6)
मेक-अरेंज फंक्शन के लिए सिंटैक्स पूरा करें
मेक-अरेंज फंक्शन कई अन्य तर्क देता है। आइए हम इस फ़ंक्शन के पूर्ण सिंटैक्स को देखें -
make-array dimensions :element-type :initial-element :initial-contents :adjustable :fill-pointer :displaced-to :displaced-index-offset
आयाम तर्क के अलावा , अन्य सभी तर्क कीवर्ड हैं। निम्न तालिका तर्कों का संक्षिप्त विवरण प्रदान करती है।
अनु क्रमांक। | तर्क और विवरण |
---|---|
1 | dimensions यह सरणी के आयाम देता है। यह एक-आयामी सरणी के लिए एक संख्या है, और बहु-आयामी सरणी के लिए एक सूची है। |
2 | :element-type यह प्रकार निर्दिष्ट करने वाला है, डिफ़ॉल्ट मान T है, अर्थात कोई भी प्रकार |
3 | :initial-element प्रारंभिक तत्व मूल्य। यह एक विशेष मूल्य के लिए प्रारंभिक सभी तत्वों के साथ एक सरणी बना देगा। |
4 | :initial-content वस्तु के रूप में प्रारंभिक सामग्री। |
5 | :adjustable यह एक रेज़िजेबल (या समायोज्य) वेक्टर बनाने में मदद करता है जिसकी अंतर्निहित मेमोरी को आकार दिया जा सकता है। तर्क एक बूलियन मान है जो इंगित करता है कि सरणी समायोज्य है या नहीं, डिफ़ॉल्ट मान NIL है। |
6 | :fill-pointer यह उन तत्वों की संख्या का पता लगाता है जो वास्तव में एक रिजिजेबल वेक्टर में संग्रहीत होते हैं। |
7 | :displaced-to यह विस्थापित सरणी या साझा सरणी बनाने में मदद करता है जो निर्दिष्ट सरणी के साथ अपनी सामग्री साझा करता है। दोनों सरणियों में समान तत्व प्रकार होना चाहिए। : विस्थापित-विकल्प का उपयोग इसके साथ नहीं किया जा सकता है: प्रारंभिक-तत्व या: प्रारंभिक-सामग्री विकल्प। यह तर्क शून्य हो जाता है। |
8 | :displaced-index-offset यह बनाए गए साझा सरणी के सूचकांक-ऑफसेट देता है। |
उदाहरण 4
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(setq myarray (make-array '(3 2 3)
:initial-contents
'(((a b c) (1 2 3))
((d e f) (4 5 6))
((g h i) (7 8 9))
))
)
(setq array2 (make-array 4 :displaced-to myarray :displaced-index-offset 2))
(write myarray)
(terpri)
(write array2)
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
#3A(((A B C) (1 2 3)) ((D E F) (4 5 6)) ((G H I) (7 8 9)))
#(C 1 2 3)
यदि विस्थापित सरणी दो आयामी है -
(setq myarray (make-array '(3 2 3)
:initial-contents
'(((a b c) (1 2 3))
((d e f) (4 5 6))
((g h i) (7 8 9))
))
)
(setq array2 (make-array '(3 2) :displaced-to myarray :displaced-index-offset 2))
(write myarray)
(terpri)
(write array2)
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
#3A(((A B C) (1 2 3)) ((D E F) (4 5 6)) ((G H I) (7 8 9)))
#2A((C 1) (2 3) (D E))
आइए विस्थापित सूचकांक ऑफसेट को 5 में बदलें -
(setq myarray (make-array '(3 2 3)
:initial-contents
'(((a b c) (1 2 3))
((d e f) (4 5 6))
((g h i) (7 8 9))
))
)
(setq array2 (make-array '(3 2) :displaced-to myarray :displaced-index-offset 5))
(write myarray)
(terpri)
(write array2)
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
#3A(((A B C) (1 2 3)) ((D E F) (4 5 6)) ((G H I) (7 8 9)))
#2A((3 D) (E F) (4 5))
उदाहरण 5
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
;a one dimensional array with 5 elements,
;initail value 5
(write (make-array 5 :initial-element 5))
(terpri)
;two dimensional array, with initial element a
(write (make-array '(2 3) :initial-element 'a))
(terpri)
;an array of capacity 14, but fill pointer 5, is 5
(write(length (make-array 14 :fill-pointer 5)))
(terpri)
;however its length is 14
(write (array-dimensions (make-array 14 :fill-pointer 5)))
(terpri)
; a bit array with all initial elements set to 1
(write(make-array 10 :element-type 'bit :initial-element 1))
(terpri)
; a character array with all initial elements set to a
; is a string actually
(write(make-array 10 :element-type 'character :initial-element #\a))
(terpri)
; a two dimensional array with initial values a
(setq myarray (make-array '(2 2) :initial-element 'a :adjustable t))
(write myarray)
(terpri)
;readjusting the array
(adjust-array myarray '(1 3) :initial-element 'b)
(write myarray)
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
#(5 5 5 5 5)
#2A((A A A) (A A A))
5
(14)
#*1111111111
"aaaaaaaaaa"
#2A((A A) (A A))
#2A((A A B))
कॉमन लिस्प में स्ट्रिंग्स वैक्टर हैं, यानी, एक आयामी चरित्र के अक्षर।
स्ट्रिंग शाब्दिक दोहरे उद्धरण चिह्नों में संलग्न हैं। चरित्र सेट द्वारा समर्थित किसी भी चरित्र को डबल उद्धरण वर्ण (") और एस्केप चरित्र (\) को छोड़कर एक स्ट्रिंग बनाने के लिए दोहरे उद्धरणों के भीतर संलग्न किया जा सकता है। हालांकि, आप उन्हें बैकस्लैश (\) के साथ भागने से शामिल कर सकते हैं।
उदाहरण
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(write-line "Hello World")
(write-line "Welcome to Tutorials Point")
;escaping the double quote character
(write-line "Welcome to \"Tutorials Point\"")
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
Hello World
Welcome to Tutorials Point
Welcome to "Tutorials Point"
स्ट्रिंग तुलनात्मक कार्य
संख्यात्मक तुलना फ़ंक्शंस और ऑपरेटर, जैसे, <और> स्ट्रिंग्स पर काम नहीं करते हैं। सामान्य LISP आपके कोड में तार की तुलना करने के लिए अन्य दो कार्य प्रदान करता है। एक सेट केस-संवेदी है और दूसरा केस-असंवेदनशील।
निम्न तालिका कार्य प्रदान करती है -
केस सेंसिटिव फंक्शंस | केस-असंवेदनशील कार्य | विवरण |
---|---|---|
स्ट्रिंग = | स्ट्रिंग-बराबर | जाँच करता है कि क्या ऑपरेंड के मान सभी समान हैं या नहीं, यदि हाँ तो स्थिति सच हो जाती है। |
स्ट्रिंग / = | स्ट्रिंग-नहीं-बराबर | जाँच करता है कि क्या संचालकों के मूल्य अलग-अलग हैं या नहीं, यदि मान समान नहीं हैं तो स्थिति सत्य हो जाती है। |
स्ट्रिंग < | स्ट्रिंग-lessp | जाँच करता है कि क्या ऑपरेंड का मान नीरस रूप से कम हो रहा है। |
स्ट्रिंग> | स्ट्रिंग-greaterp | जाँच करता है कि क्या ऑपरेंड का मान नीरस रूप से बढ़ रहा है। |
स्ट्रिंग <= | स्ट्रिंग-नहीं-greaterp | यह जांचता है कि क्या किसी भी बाएं संकार्य का मान अगले दाहिने संचालक के मान से अधिक या उसके बराबर है, यदि हाँ, तो स्थिति सत्य है। |
स्ट्रिंग> = | स्ट्रिंग-नहीं-lessp | यह जांचता है कि क्या किसी भी बाएं संकार्य का मूल्य उसके दाहिने संचालक के मूल्य से कम या उसके बराबर है, यदि हाँ तो स्थिति सत्य हो जाती है। |
उदाहरण
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
; case-sensitive comparison
(write (string= "this is test" "This is test"))
(terpri)
(write (string> "this is test" "This is test"))
(terpri)
(write (string< "this is test" "This is test"))
(terpri)
;case-insensitive comparision
(write (string-equal "this is test" "This is test"))
(terpri)
(write (string-greaterp "this is test" "This is test"))
(terpri)
(write (string-lessp "this is test" "This is test"))
(terpri)
;checking non-equal
(write (string/= "this is test" "this is Test"))
(terpri)
(write (string-not-equal "this is test" "This is test"))
(terpri)
(write (string/= "lisp" "lisping"))
(terpri)
(write (string/= "decent" "decency"))
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
NIL
0
NIL
T
NIL
NIL
8
NIL
4
5
केस कंट्रोलिंग फ़ंक्शंस
निम्न तालिका कार्य नियंत्रण के मामले का वर्णन करती है -
अनु क्रमांक। | समारोह विवरण |
---|---|
1 | string-upcase स्ट्रिंग को ऊपरी मामले में परिवर्तित करता है |
2 | string-downcase स्ट्रिंग को निचले मामले में परिवर्तित करता है |
3 | string-capitalize प्रत्येक शब्द को स्ट्रिंग में कैपिटल करता है |
उदाहरण
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(write-line (string-upcase "a big hello from tutorials point"))
(write-line (string-capitalize "a big hello from tutorials point"))
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
A BIG HELLO FROM TUTORIALS POINT
A Big Hello From Tutorials Point
स्ट्रिमिंग स्ट्रिंग्स
निम्न तालिका स्ट्रिंग ट्रिमिंग कार्यों का वर्णन करती है -
अनु क्रमांक। | समारोह विवरण |
---|---|
1 | string-trim यह पहले तर्क के रूप में एक स्ट्रिंग (अक्षर) और दूसरे तर्क के रूप में एक स्ट्रिंग लेता है और एक विकल्प देता है जहां पहले तर्क में सभी वर्ण तर्क स्ट्रिंग से हटा दिए जाते हैं। |
2 | String-left-trim यह पहली दलील के रूप में एक अक्षर (एस) और दूसरी तर्क के रूप में एक स्ट्रिंग लेता है और एक विकल्प देता है जहां पहले तर्क में मौजूद सभी वर्ण तर्क स्ट्रिंग की शुरुआत से हटा दिए जाते हैं। |
3 | String-right-trim यह पहले तर्क के रूप में एक स्ट्रिंग चरित्र (एस) और दूसरे तर्क के रूप में एक स्ट्रिंग लेता है और एक विकल्प देता है जहां पहले तर्क में मौजूद सभी वर्ण तर्क स्ट्रिंग के अंत से हटा दिए जाते हैं। |
उदाहरण
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(write-line (string-trim " " " a big hello from tutorials point "))
(write-line (string-left-trim " " " a big hello from tutorials point "))
(write-line (string-right-trim " " " a big hello from tutorials point "))
(write-line (string-trim " a" " a big hello from tutorials point "))
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
a big hello from tutorials point
a big hello from tutorials point
a big hello from tutorials point
big hello from tutorials point
अन्य स्ट्रिंग फ़ंक्शंस
LISP में स्ट्रिंग्स एरेज़ हैं और इस तरह से सीक्वेंस भी हैं। हम आने वाले ट्यूटोरियल में इन डेटा प्रकारों को कवर करेंगे। सभी फ़ंक्शन जो सरणियों और अनुक्रमों पर लागू होते हैं, वे स्ट्रिंग्स पर भी लागू होते हैं। हालाँकि, हम विभिन्न उदाहरणों का उपयोग करते हुए कुछ आमतौर पर उपयोग किए जाने वाले कार्यों का प्रदर्शन करेंगे।
लंबाई की गणना
length फ़ंक्शन एक स्ट्रिंग की लंबाई की गणना करता है।
उप-स्ट्रिंग निकालना
subseq फ़ंक्शन एक विशेष इंडेक्स पर शुरू होने और एक विशेष एंडिंग इंडेक्स या स्ट्रिंग के अंत तक जारी रखने के लिए एक उप-स्ट्रिंग (एक स्ट्रिंग भी एक अनुक्रम है) देता है।
स्ट्रिंग में कैरेक्टर एक्सेस करना
char फ़ंक्शन एक स्ट्रिंग के व्यक्तिगत पात्रों तक पहुंचने की अनुमति देता है।
Example
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(write (length "Hello World"))
(terpri)
(write-line (subseq "Hello World" 6))
(write (char "Hello World" 6))
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
11
World
#\W
स्ट्रिंग्स की छंटाई और विलय
sortफ़ंक्शन एक स्ट्रिंग को सॉर्ट करने की अनुमति देता है। यह एक अनुक्रम (वेक्टर या स्ट्रिंग) और एक दो-तर्क विधेय करता है और अनुक्रम का एक क्रमबद्ध संस्करण लौटाता है।
merge फ़ंक्शन दो अनुक्रमों और एक विधेय को लेता है और एक अनुक्रम को दो अनुक्रमों को विलय करके उत्पादित करता है, जो कि विधेय के अनुसार है।
Example
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
;sorting the strings
(write (sort (vector "Amal" "Akbar" "Anthony") #'string<))
(terpri)
;merging the strings
(write (merge 'vector (vector "Rishi" "Zara" "Priyanka")
(vector "Anju" "Anuj" "Avni") #'string<))
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
#("Akbar" "Amal" "Anthony")
#("Anju" "Anuj" "Avni" "Rishi" "Zara" "Priyanka")
एक स्ट्रिंग उलट
reverse फ़ंक्शन एक स्ट्रिंग को उलट देता है।
उदाहरण के लिए, main.lisp नाम से एक नया स्रोत कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(write-line (reverse "Are we not drawn onward, we few, drawn onward to new era"))
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
are wen ot drawno nward ,wef ew ,drawno nward ton ew erA
कॉनटेटनेटिंग स्ट्रिंग्स
समतलन समारोह दो तारों को समेटता है। यह सामान्य अनुक्रम फ़ंक्शन है और आपको पहले तर्क के रूप में परिणाम प्रकार प्रदान करना होगा।
उदाहरण के लिए, main.lisp नाम से एक नया स्रोत कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(write-line (concatenate 'string "Are we not drawn onward, " "we few, drawn onward to new era"))
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
Are we not drawn onward, we few, drawn onward to new era
अनुक्रम LISP में एक सार डेटा प्रकार है। वैक्टर और सूचियाँ इस डेटा प्रकार के दो ठोस उपप्रकार हैं। अनुक्रम डेटा प्रकार पर परिभाषित सभी फ़ंक्शंस वास्तव में सभी वैक्टर और सूची प्रकारों पर लागू होते हैं।
इस खंड में, हम अनुक्रमों पर सबसे अधिक इस्तेमाल किए जाने वाले कार्यों पर चर्चा करेंगे।
अनुक्रमों (यानी, वैक्टर और सूचियों) में हेरफेर करने के विभिन्न तरीकों पर शुरू करने से पहले, आइए हम सभी उपलब्ध कार्यों की सूची पर एक नज़र डालें।
अनुक्रम बनाना
फंक्शन मेक-सीक्वेंस आपको किसी भी प्रकार का सीक्वेंस बनाने की अनुमति देता है। इस फ़ंक्शन का सिंटैक्स है -
make-sequence sqtype sqsize &key :initial-element
यह प्रकार sqtype और लंबाई sqsize का एक क्रम बनाता है ।
आप वैकल्पिक रूप से : प्रारंभिक-तत्व तर्क का उपयोग करते हुए कुछ मान निर्दिष्ट कर सकते हैं , फिर प्रत्येक तत्व इस मूल्य के लिए आरंभिक होगा।
उदाहरण के लिए, main.lisp नाम से एक नया स्रोत कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(write (make-sequence '(vector float)
10
:initial-element 1.0))
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
#(1.0 1.0 1.0 1.0 1.0 1.0 1.0 1.0 1.0 1.0)
अनुक्रम पर सामान्य कार्य
अनु क्रमांक। | समारोह विवरण |
---|---|
1 | elt यह एक पूर्णांक सूचकांक के माध्यम से व्यक्तिगत तत्वों तक पहुंच की अनुमति देता है। |
2 | length यह एक अनुक्रम की लंबाई लौटाता है। |
3 | subseq यह एक विशेष सूचकांक पर शुरू होने वाले अनुक्रम को निकालने और एक विशेष समाप्ति सूचकांक या अनुक्रम के अंत तक जारी रखते हुए एक उप-अनुक्रम देता है। |
4 | copy-seq यह एक अनुक्रम देता है जिसमें उसके तर्क के समान तत्व होते हैं। |
5 | fill इसका उपयोग अनुक्रम के कई तत्वों को एकल मान पर सेट करने के लिए किया जाता है। |
6 | replace यह दो क्रम लेता है और पहला तर्क अनुक्रम विनाशकारी रूप से क्रमिक तत्वों को दूसरे तर्क अनुक्रम से कॉपी करके संशोधित किया जाता है। |
7 | count यह एक आइटम और एक अनुक्रम लेता है और अनुक्रम में आइटम के प्रकट होने की संख्या को वापस करता है। |
8 | reverse यह एक अनुक्रम देता है जिसमें तर्क के समान तत्व होते हैं लेकिन रिवर्स ऑर्डर में। |
9 | nreverse यह उसी अनुक्रम को देता है जिसमें अनुक्रम के समान तत्व होते हैं लेकिन रिवर्स ऑर्डर में। |
10 | concatenate यह एक नए अनुक्रम का निर्माण करता है जिसमें किसी भी संख्या के अनुक्रमों का संयोजन होता है। |
1 1 | position यह एक आइटम और एक अनुक्रम लेता है और अनुक्रम या नील में आइटम के सूचकांक को वापस करता है। |
12 | find यह एक आइटम और एक अनुक्रम लेता है। यह आइटम को अनुक्रम में पाता है और उसे वापस लौटाता है, यदि नहीं मिला है तो यह शून्य देता है। |
13 | sort यह एक अनुक्रम लेता है और एक दो-तर्क विधेय करता है और अनुक्रम का एक क्रमबद्ध संस्करण लौटाता है। |
14 | merge यह दो अनुक्रमों और एक विधेय को लेता है और एक अनुक्रम को दो अनुक्रमों को विलय करके उत्पादित करता है, जो कि विधेय के अनुसार है। |
15 | map यह एक एन-तर्क फ़ंक्शन और एन अनुक्रम लेता है और अनुक्रमों के बाद के तत्वों में फ़ंक्शन को लागू करने के परिणामस्वरूप एक नया अनुक्रम देता है। |
16 | some यह एक तर्क के रूप में एक विधेय लेता है और तर्क अनुक्रम पर पुनरावृत्ति करता है, और विधेय द्वारा लौटाया गया पहला गैर-एनआईएल मान लौटाता है या यदि विधेय कभी संतुष्ट नहीं होता है तो वापस लौटता है। |
17 | every यह एक तर्क के रूप में एक विधेय लेता है और तर्क अनुक्रम पर पुनरावृति करता है, यह समाप्त होता है, जैसे ही विधेय विफल होता है, वापस लौटता है। यदि विधेय हमेशा संतुष्ट रहता है, तो यह सच है। |
18 | notany यह एक तर्क के रूप में एक विधेय लेता है और तर्क अनुक्रम पर पुनरावृति करता है, और यह झूठे के रूप में जल्द ही लौटता है यदि विधेय संतुष्ट या सच है यदि यह कभी नहीं है। |
19 | notevery यह तर्क के रूप में एक विधेय को ले जाता है और तर्क अनुक्रम पर पुनरावृति करता है, और जैसे ही विधेय हमेशा संतुष्ट होता है, वैसे ही भविष्यवाणी विफल या झूठी हो जाती है। |
20 | reduce यह एक एकल अनुक्रम पर मैप करता है, पहले अनुक्रम के पहले दो तत्वों के लिए दो-तर्क फ़ंक्शन को लागू करता है और फिर फ़ंक्शन और अनुक्रम के बाद के तत्वों द्वारा लौटाए गए मान पर। |
21 | search यह कुछ परीक्षण को संतुष्ट करने वाले एक या अधिक तत्वों का पता लगाने के लिए एक क्रम को खोजता है। |
22 | remove यह एक आइटम और एक अनुक्रम लेता है और हटाए गए आइटम के उदाहरणों के साथ अनुक्रम लौटाता है। |
23 | delete यह एक आइटम और एक अनुक्रम भी लेता है और तर्क क्रम का उसी प्रकार का अनुक्रम देता है जिसमें आइटम को छोड़कर समान तत्व होते हैं। |
24 | substitute यह एक नया आइटम, एक मौजूदा आइटम और एक अनुक्रम लेता है और नए आइटम के साथ प्रतिस्थापित मौजूदा आइटम के उदाहरणों के साथ एक अनुक्रम देता है। |
25 | nsubstitute यह एक नया आइटम, एक मौजूदा आइटम और एक अनुक्रम लेता है और उसी क्रम को मौजूदा आइटम के उदाहरणों के साथ नए आइटम के साथ बदल देता है। |
26 | mismatch यह दो क्रम लेता है और बेमेल तत्वों की पहली जोड़ी का सूचकांक लौटाता है। |
मानक अनुक्रम समारोह कीवर्ड तर्क
बहस | जिसका अर्थ है | डिफ़ॉल्ट मान |
---|---|---|
:परीक्षा | यह एक दो-तर्क फ़ंक्शन है जिसका उपयोग तत्व (या मुख्य फ़ंक्शन द्वारा निकाले गए मूल्य) की तुलना करने के लिए किया जाता है। | EQL |
:चाभी | वास्तविक अनुक्रम तत्व से मुख्य मान निकालने के लिए एक-तर्क फ़ंक्शन। NIL का अर्थ है तत्व का उपयोग करें जैसा कि है। | शून्य |
:शुरू | अनुक्रमणिका (समावेशी) की शुरुआत। | 0 |
:समाप्त | अंत का सूचकांक (अनन्य)। NIL अनुक्रम के अंत को इंगित करता है। | शून्य |
: अंत से | यदि सत्य है, तो अनुक्रम को अंत से शुरू होने तक, रिवर्स ऑर्डर में ट्रेस किया जाएगा। | शून्य |
: गिनती | सभी को हटाने के लिए या NIL को हटाने या बदलने के लिए तत्वों की संख्या को इंगित करने वाली संख्या (केवल REMOVE और SUBSTITUTE)। | शून्य |
हमने अभी विभिन्न कार्यों और खोजशब्दों पर चर्चा की है जो अनुक्रमों पर काम करने वाले इन कार्यों में तर्क के रूप में उपयोग किए जाते हैं। अगले खंडों में, हम देखेंगे कि उदाहरणों का उपयोग करके इन कार्यों का उपयोग कैसे करें।
लंबाई और तत्व ढूँढना
length फ़ंक्शन एक अनुक्रम की लंबाई देता है, और elt फ़ंक्शन आपको पूर्णांक सूचकांक का उपयोग करके व्यक्तिगत तत्वों तक पहुंचने की अनुमति देता है।
उदाहरण
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(setq x (vector 'a 'b 'c 'd 'e))
(write (length x))
(terpri)
(write (elt x 3))
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
5
D
अनुक्रमों को संशोधित करना
कुछ अनुक्रम फ़ंक्शंस अनुक्रम के माध्यम से पुनरावृत्ति की अनुमति देते हैं और कुछ ऑपरेशन करते हैं जैसे, स्पष्ट लूप लिखने के बिना विशिष्ट तत्वों को खोजना, निकालना, गिनना या फ़िल्टर करना।
निम्न उदाहरण यह प्रदर्शित करता है -
उदाहरण 1
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(write (count 7 '(1 5 6 7 8 9 2 7 3 4 5)))
(terpri)
(write (remove 5 '(1 5 6 7 8 9 2 7 3 4 5)))
(terpri)
(write (delete 5 '(1 5 6 7 8 9 2 7 3 4 5)))
(terpri)
(write (substitute 10 7 '(1 5 6 7 8 9 2 7 3 4 5)))
(terpri)
(write (find 7 '(1 5 6 7 8 9 2 7 3 4 5)))
(terpri)
(write (position 5 '(1 5 6 7 8 9 2 7 3 4 5)))
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
2
(1 6 7 8 9 2 7 3 4)
(1 6 7 8 9 2 7 3 4)
(1 5 6 10 8 9 2 10 3 4 5)
7
1
उदाहरण 2
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(write (delete-if #'oddp '(1 5 6 7 8 9 2 7 3 4 5)))
(terpri)
(write (delete-if #'evenp '(1 5 6 7 8 9 2 7 3 4 5)))
(terpri)
(write (remove-if #'evenp '(1 5 6 7 8 9 2 7 3 4 5) :count 1 :from-end t))
(terpri)
(setq x (vector 'a 'b 'c 'd 'e 'f 'g))
(fill x 'p :start 1 :end 4)
(write x)
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
(6 8 2 4)
(1 5 7 9 7 3 5)
(1 5 6 7 8 9 2 7 3 5)
#(A P P P E F G)
क्रमबद्धता और विलय अनुक्रम
सॉर्टिंग फ़ंक्शन एक अनुक्रम लेते हैं और दो-तर्क विधेय करते हैं और अनुक्रम के एक सॉर्ट किए गए संस्करण को वापस करते हैं।
उदाहरण 1
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(write (sort '(2 4 7 3 9 1 5 4 6 3 8) #'<))
(terpri)
(write (sort '(2 4 7 3 9 1 5 4 6 3 8) #'>))
(terpri)
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
(1 2 3 3 4 4 5 6 7 8 9)
(9 8 7 6 5 4 4 3 3 2 1)
उदाहरण 2
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(write (merge 'vector #(1 3 5) #(2 4 6) #'<))
(terpri)
(write (merge 'list #(1 3 5) #(2 4 6) #'<))
(terpri)
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
#(1 2 3 4 5 6)
(1 2 3 4 5 6)
अनुक्रम की भविष्यवाणी करता है
प्रत्येक कार्य, कुछ, कुछ, और नोटबंदी को अनुक्रम की भविष्यवाणी कहा जाता है।
ये कार्य अनुक्रमों पर पुनरावृति करते हैं और बूलियन का परीक्षण करते हैं।
ये सभी कार्य पहले तर्क के रूप में एक भविष्यवाणी करते हैं और शेष तर्क क्रम होते हैं।
उदाहरण
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(write (every #'evenp #(2 4 6 8 10)))
(terpri)
(write (some #'evenp #(2 4 6 8 10 13 14)))
(terpri)
(write (every #'evenp #(2 4 6 8 10 13 14)))
(terpri)
(write (notany #'evenp #(2 4 6 8 10)))
(terpri)
(write (notevery #'evenp #(2 4 6 8 10 13 14)))
(terpri)
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
T
T
NIL
NIL
T
मानचित्रण अनुक्रम
हमने मैपिंग फ़ंक्शन पर पहले ही चर्चा की है। इसी प्रकार दmap फ़ंक्शन आपको एक या अधिक अनुक्रम के बाद के तत्वों पर एक फ़ंक्शन लागू करने की अनुमति देता है।
map फ़ंक्शन एक n- तर्क फ़ंक्शन और n अनुक्रम लेता है और बाद के अनुक्रमों के फ़ंक्शन को लागू करने के बाद एक नया अनुक्रम देता है।
उदाहरण
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(write (map 'vector #'* #(2 3 4 5) #(3 5 4 8)))
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
#(6 15 16 40)
पारंपरिक LISP में सूचियाँ सबसे महत्वपूर्ण और प्राथमिक समग्र डेटा संरचना थीं। वर्तमान दिन की आम LISP अन्य डेटा संरचनाएं प्रदान करती है, जैसे कि वेक्टर, हैश टेबल, कक्षाएं या संरचनाएं।
सूची एकल लिंक की गई सूची है। LISP में, सूचियों का निर्माण एक सरल रिकॉर्ड संरचना के नाम से किया जाता हैcons आपस मे जुड़े हैं।
विपक्ष रिकॉर्ड संरचना
ए cons एक रिकॉर्ड संरचना है जिसमें दो घटक होते हैं जिन्हें कहा जाता है car और यह cdr.
विपक्ष कोशिकाएं या विपक्ष ऑब्जेक्ट हैं जो फ़ंक्शन का उपयोग करके बनाए गए मानों के जोड़े हैं cons.
consफ़ंक्शन दो तर्क लेता है और दो मूल्यों वाले एक नए कॉन्स सेल देता है। ये मूल्य किसी भी प्रकार की वस्तु के संदर्भ हो सकते हैं।
यदि दूसरा मान शून्य नहीं है, या अन्य कंसोल सेल है, तो मान को कोष्ठक द्वारा संलग्न बिंदीदार जोड़ी के रूप में मुद्रित किया जाता है।
एक आम सेल में दो मानों को कहा जाता है car और यह cdr. car फ़ंक्शन का उपयोग पहले मान और उपयोग करने के लिए किया जाता है cdr फ़ंक्शन का उपयोग दूसरे मान तक पहुंचने के लिए किया जाता है।
उदाहरण
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(write (cons 1 2))
(terpri)
(write (cons 'a 'b))
(terpri)
(write (cons 1 nil))
(terpri)
(write (cons 1 (cons 2 nil)))
(terpri)
(write (cons 1 (cons 2 (cons 3 nil))))
(terpri)
(write (cons 'a (cons 'b (cons 'c nil))))
(terpri)
(write ( car (cons 'a (cons 'b (cons 'c nil)))))
(terpri)
(write ( cdr (cons 'a (cons 'b (cons 'c nil)))))
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
(1 . 2)
(A . B)
(1)
(1 2)
(1 2 3)
(A B C)
A
(B C)
उपर्युक्त उदाहरण से पता चलता है कि कैसे एक एकल लिंक की गई सूची बनाने के लिए विपक्ष संरचनाओं का उपयोग किया जा सकता है, उदाहरण के लिए, सूची (एबीसी) में तीन सीडी कोशिकाएं होती हैं जो एक साथ अपने सीडीआर द्वारा जुड़ी होती हैं ।
आरेखीय रूप से, इसे इस प्रकार व्यक्त किया जा सकता है -
LISP में सूचीबद्ध है
हालाँकि, सूची बनाने के लिए cons कोशिकाओं का उपयोग किया जा सकता है, हालाँकि, नेस्टेड में से एक सूची का निर्माण करना consफ़ंक्शन कॉल सबसे अच्छा समाधान नहीं हो सकता है। list फ़ंक्शन का उपयोग LISP में सूची बनाने के लिए किया जाता है।
सूची फ़ंक्शन किसी भी तर्क ले सकता है और जैसा कि यह एक फ़ंक्शन है, यह अपने तर्कों का मूल्यांकन करता है।
first तथा restफ़ंक्शंस पहला तत्व और सूची का बाकी हिस्सा देते हैं। निम्नलिखित उदाहरण अवधारणाओं को प्रदर्शित करते हैं।
उदाहरण 1
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(write (list 1 2))
(terpri)
(write (list 'a 'b))
(terpri)
(write (list 1 nil))
(terpri)
(write (list 1 2 3))
(terpri)
(write (list 'a 'b 'c))
(terpri)
(write (list 3 4 'a (car '(b . c)) (* 4 -2)))
(terpri)
(write (list (list 'a 'b) (list 'c 'd 'e)))
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
(1 2)
(A B)
(1 NIL)
(1 2 3)
(A B C)
(3 4 A B -8)
((A B) (C D E))
उदाहरण 2
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(defun my-library (title author rating availability)
(list :title title :author author :rating rating :availabilty availability)
)
(write (getf (my-library "Hunger Game" "Collins" 9 t) :title))
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
"Hunger Game"
सूची मैनिपुलेटिंग कार्य
निम्न तालिका कुछ आमतौर पर इस्तेमाल की जाने वाली सूची हेरफेर कार्यों को प्रदान करती है।
अनु क्रमांक। | समारोह विवरण |
---|---|
1 | car यह एक सूची को तर्क के रूप में लेता है, और इसका पहला तत्व देता है। |
2 | cdr यह एक सूची को तर्क के रूप में लेता है, और पहले तत्व के बिना एक सूची देता है |
3 | cons यह दो तर्क लेता है, एक तत्व और एक सूची और पहले स्थान पर डाले गए तत्व के साथ एक सूची देता है। |
4 | list यह किसी भी संख्या में तर्क लेता है और सूची के सदस्य तत्वों के रूप में तर्कों के साथ एक सूची देता है। |
5 | append यह दो या अधिक सूची को एक में मिला देता है। |
6 | last यह एक सूची लेता है और एक सूची देता है जिसमें अंतिम तत्व होता है। |
7 | member इसमें दो तर्क होते हैं, जिनमें से एक दूसरे की सूची होना चाहिए, यदि पहला तर्क दूसरे तर्क का सदस्य है, और फिर यह पहले तर्क के साथ शुरू होने वाली सूची के शेष को लौटाता है। |
8 | reverse यह एक सूची लेता है और रिवर्स ऑर्डर में शीर्ष तत्वों के साथ एक सूची देता है। |
कृपया ध्यान दें कि सभी अनुक्रम कार्य सूचियों पर लागू होते हैं।
उदाहरण 3
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(write (car '(a b c d e f)))
(terpri)
(write (cdr '(a b c d e f)))
(terpri)
(write (cons 'a '(b c)))
(terpri)
(write (list 'a '(b c) '(e f)))
(terpri)
(write (append '(b c) '(e f) '(p q) '() '(g)))
(terpri)
(write (last '(a b c d (e f))))
(terpri)
(write (reverse '(a b c d (e f))))
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
A
(B C D E F)
(A B C)
(A (B C) (E F))
(B C E F P Q G)
((E F))
((E F) D C B A)
कार और सीडीआर कार्यों का संयोजन
car तथा cdr फ़ंक्शंस और उनका संयोजन किसी सूची के किसी विशेष तत्व / सदस्य को निकालने की अनुमति देता है।
हालाँकि, कार और cdr फंक्शंस के सीक्वेंस को अक्षर c के लिए कार और d के लिए अक्षर c और r के अंदर संक्षिप्त करके संक्षिप्त किया जा सकता है।
उदाहरण के लिए, हम फ़ंक्शन कॉल के अनुक्रम को संक्षिप्त करने के लिए कैडडर लिख सकते हैं - कार सीडीआर कार सीडीआर।
इस प्रकार, (Cadadr '((cd) (efg)) d वापस आ जाएगी
उदाहरण 4
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(write (cadadr '(a (c d) (e f g))))
(terpri)
(write (caar (list (list 'a 'b) 'c)))
(terpri)
(write (cadr (list (list 1 2) (list 3 4))))
(terpri)
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
D
A
(3 4)
LISP में, एक प्रतीक एक ऐसा नाम है जो डेटा ऑब्जेक्ट का प्रतिनिधित्व करता है और दिलचस्प रूप से यह एक डेटा ऑब्जेक्ट भी है।
प्रतीकों को क्या खास बनाता है कि उनके पास एक घटक होता है जिसे कहा जाता है property list, या plist.
संपत्ति सूची
LISP आपको प्रतीकों को गुण प्रदान करने की अनुमति देता है। उदाहरण के लिए, हमारे पास एक 'व्यक्ति' वस्तु है। हम चाहेंगे कि इस 'व्यक्ति' की वस्तु में नाम, लिंग, ऊँचाई, वजन, पता, पेशा आदि गुण हों। एक गुण गुण नाम की तरह होता है।
एक संपत्ति सूची तत्वों की एक समान संख्या (संभवतः शून्य) के साथ एक सूची के रूप में लागू की जाती है। सूची में तत्वों की प्रत्येक जोड़ी एक प्रविष्टि का गठन करती है; पहला आइटम हैindicator, और दूसरा है value.
जब एक प्रतीक बनाया जाता है, तो इसकी संपत्ति सूची शुरू में खाली होती है। गुणों का उपयोग करके बनाया जाता हैget के अंदर setf प्रपत्र।
उदाहरण के लिए, निम्नलिखित कथन हमें 'पुस्तक' नाम की एक वस्तु के लिए गुण शीर्षक, लेखक और प्रकाशक और संबंधित मान निर्दिष्ट करने की अनुमति देते हैं।
उदाहरण 1
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(write (setf (get 'books'title) '(Gone with the Wind)))
(terpri)
(write (setf (get 'books 'author) '(Margaret Michel)))
(terpri)
(write (setf (get 'books 'publisher) '(Warner Books)))
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
(GONE WITH THE WIND)
(MARGARET MICHEL)
(WARNER BOOKS)
विभिन्न संपत्ति सूची फ़ंक्शंस आपको एक प्रतीक के गुणों को पुन: प्रस्तुत करने, प्रतिस्थापित करने या हटाने के लिए गुणों को असाइन करने की अनुमति देते हैं।
getफ़ंक्शन दिए गए संकेतक के लिए प्रतीक की संपत्ति सूची देता है। इसके निम्नलिखित सिंटैक्स हैं -
get symbol indicator &optional default
getफ़ंक्शन निर्दिष्ट संकेतक के लिए दिए गए प्रतीक की संपत्ति सूची की तलाश करता है, यदि यह पाया जाता है तो यह संबंधित मान लौटाता है; अन्यथा डिफ़ॉल्ट लौटाया जाता है (या यदि कोई डिफ़ॉल्ट मान निर्दिष्ट नहीं किया गया है), तो शून्य।
उदाहरण 2
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(setf (get 'books 'title) '(Gone with the Wind))
(setf (get 'books 'author) '(Margaret Micheal))
(setf (get 'books 'publisher) '(Warner Books))
(write (get 'books 'title))
(terpri)
(write (get 'books 'author))
(terpri)
(write (get 'books 'publisher))
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
(GONE WITH THE WIND)
(MARGARET MICHEAL)
(WARNER BOOKS)
symbol-plist फ़ंक्शन आपको एक प्रतीक के सभी गुणों को देखने की अनुमति देता है।
उदाहरण 3
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(setf (get 'annie 'age) 43)
(setf (get 'annie 'job) 'accountant)
(setf (get 'annie 'sex) 'female)
(setf (get 'annie 'children) 3)
(terpri)
(write (symbol-plist 'annie))
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
(CHILDREN 3 SEX FEMALE JOB ACCOUNTANT AGE 43)
remprop फ़ंक्शन एक प्रतीक से निर्दिष्ट संपत्ति को निकालता है।
उदाहरण 4
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(setf (get 'annie 'age) 43)
(setf (get 'annie 'job) 'accountant)
(setf (get 'annie 'sex) 'female)
(setf (get 'annie 'children) 3)
(terpri)
(write (symbol-plist 'annie))
(remprop 'annie 'age)
(terpri)
(write (symbol-plist 'annie))
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
(CHILDREN 3 SEX FEMALE JOB ACCOUNTANT AGE 43)
(CHILDREN 3 SEX FEMALE JOB ACCOUNTANT)
वैक्टर एक-आयामी सरणियाँ हैं, इसलिए सरणी का एक उपप्रकार। वैक्टर और सूचियों को सामूहिक रूप से अनुक्रम कहा जाता है। इसलिए सभी अनुक्रम जेनेरिक फ़ंक्शंस और सरणी फ़ंक्शंस पर हमने अब तक चर्चा की है, वैक्टर पर काम करते हैं।
वैक्टर बनाना
वेक्टर फ़ंक्शन आपको विशिष्ट मानों के साथ निश्चित आकार के वैक्टर बनाने की अनुमति देता है। यह किसी भी संख्या में तर्क लेता है और उन तर्कों वाले वेक्टर को लौटाता है।
उदाहरण 1
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(setf v1 (vector 1 2 3 4 5))
(setf v2 #(a b c d e))
(setf v3 (vector 'p 'q 'r 's 't))
(write v1)
(terpri)
(write v2)
(terpri)
(write v3)
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
#(1 2 3 4 5)
#(A B C D E)
#(P Q R S T)
कृपया ध्यान दें कि LISP वैक्टर के लिए शाब्दिक अंकन के रूप में # (...) सिंटैक्स का उपयोग करता है। आप अपने कोड में शाब्दिक वैक्टर बनाने और शामिल करने के लिए इस (...) सिंटैक्स का उपयोग कर सकते हैं।
हालाँकि, ये शाब्दिक वैक्टर हैं, इसलिए इन्हें संशोधित करना LISP में परिभाषित नहीं है। इसलिए, प्रोग्रामिंग के लिए, आपको हमेशा उपयोग करना चाहिएvector फ़ंक्शन, या अधिक सामान्य फ़ंक्शन make-array वैक्टर बनाने के लिए आप संशोधित करने की योजना बनाते हैं।
make-arrayवेक्टर बनाने के लिए फ़ंक्शन अधिक सामान्य तरीका है। आप वेक्टर तत्वों का उपयोग कर सकते हैंaref समारोह।
उदाहरण 2
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(setq a (make-array 5 :initial-element 0))
(setq b (make-array 5 :initial-element 2))
(dotimes (i 5)
(setf (aref a i) i))
(write a)
(terpri)
(write b)
(terpri)
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
#(0 1 2 3 4)
#(2 2 2 2 2)
पॉइंटर भरें
make-array फ़ंक्शन आपको एक resizable वेक्टर बनाने की अनुमति देता है।
fill-pointerफ़ंक्शन का तर्क वेक्टर में वास्तव में संग्रहीत तत्वों की संख्या का ट्रैक रखता है। जब आप वेक्टर में कोई तत्व जोड़ते हैं तो यह अगली स्थिति का सूचकांक होता है।
vector-pushफ़ंक्शन आपको एक resizable वेक्टर के अंत में एक तत्व जोड़ने की अनुमति देता है। यह भरण-सूचक को 1 से बढ़ाता है।
vector-pop फ़ंक्शन सबसे हाल ही में धकेल दिया गया आइटम लौटाता है और 1 से भरने वाले सूचक को घटाता है।
उदाहरण
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(setq a (make-array 5 :fill-pointer 0))
(write a)
(vector-push 'a a)
(vector-push 'b a)
(vector-push 'c a)
(terpri)
(write a)
(terpri)
(vector-push 'd a)
(vector-push 'e a)
;this will not be entered as the vector limit is 5
(vector-push 'f a)
(write a)
(terpri)
(vector-pop a)
(vector-pop a)
(vector-pop a)
(write a)
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
#()
#(A B C)
#(A B C D E)
#(A B)
वैक्टर अनुक्रम हो रहे हैं, सभी अनुक्रम कार्य वैक्टर के लिए लागू होते हैं। वेक्टर कार्यों के लिए कृपया अनुक्रम अध्याय से परामर्श करें।
आम लिस्प एक सेट डेटा प्रकार प्रदान नहीं करता है। हालांकि, यह उन कार्यों की संख्या प्रदान करता है जो सेट संचालन को किसी सूची में करने की अनुमति देता है।
आप विभिन्न मानदंडों के आधार पर सूची में आइटम जोड़ सकते हैं, हटा सकते हैं और खोज सकते हैं। आप विभिन्न सेट ऑपरेशन भी कर सकते हैं जैसे: यूनियन, चौराहा और सेट अंतर।
LISP में सेट लागू करना
सेट, सूची की तरह आम तौर पर बुरा कोशिकाओं के मामले में लागू किया जाता है। हालाँकि, इस कारण से, सेट संचालन कम और कुशल हो जाता है जितना बड़ा सेट मिलता है।
adjoinफ़ंक्शन आपको एक सेट बनाने की अनुमति देता है। यह एक आइटम और एक सूची लेता है जो एक सेट का प्रतिनिधित्व करता है और एक सूची देता है जिसमें मूल सेट में आइटम और सभी आइटमों का प्रतिनिधित्व होता है।
adjoinफ़ंक्शन पहले दिए गए सूची में आइटम की तलाश करता है, अगर यह पाया जाता है, तो यह मूल सूची लौटाता है; अन्यथा यह अपने साथ एक नया वाणिज्य प्रकोष्ठ बनाता हैcar आइटम के रूप में और cdr मूल सूची की ओर इशारा करते हुए और यह नई सूची लौटाता है।
adjoin फंक्शन भी लेता है :key तथा :testकीवर्ड तर्क। इन तर्कों का उपयोग यह जांचने के लिए किया जाता है कि आइटम मूल सूची में मौजूद है या नहीं।
चूंकि, आसन्न फ़ंक्शन मूल सूची को संशोधित नहीं करता है, इसलिए सूची में खुद को बदलने के लिए, आपको या तो मूल सूची में adjoin द्वारा दिए गए मान को असाइन करना होगा या, आप मैक्रो का उपयोग कर सकते हैं pushnew सेट में एक आइटम जोड़ने के लिए।
उदाहरण
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
; creating myset as an empty list
(defparameter *myset* ())
(adjoin 1 *myset*)
(adjoin 2 *myset*)
; adjoin did not change the original set
;so it remains same
(write *myset*)
(terpri)
(setf *myset* (adjoin 1 *myset*))
(setf *myset* (adjoin 2 *myset*))
;now the original set is changed
(write *myset*)
(terpri)
;adding an existing value
(pushnew 2 *myset*)
;no duplicate allowed
(write *myset*)
(terpri)
;pushing a new value
(pushnew 3 *myset*)
(write *myset*)
(terpri)
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
NIL
(2 1)
(2 1)
(3 2 1)
चेकिंग सदस्यता
फ़ंक्शन का सदस्य समूह आपको यह जांचने की अनुमति देता है कि कोई तत्व सेट का सदस्य है या नहीं।
इन कार्यों के वाक्य विन्यास निम्नलिखित हैं -
member item list &key :test :test-not :key
member-if predicate list &key :key
member-if-not predicate list &key :key
ये फ़ंक्शन किसी दिए गए आइटम के लिए दी गई सूची को खोजते हैं जो परीक्षण को संतुष्ट करता है। यदि ऐसा कोई आइटम नहीं मिला है, तो फ़ंक्शन वापस लौटता हैnil. अन्यथा, पहले तत्व के रूप में तत्व के साथ सूची की पूंछ वापस आ गई है।
खोज शीर्ष स्तर पर ही की जाती है।
इन कार्यों का उपयोग विधेय के रूप में किया जा सकता है।
उदाहरण
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(write (member 'zara '(ayan abdul zara riyan nuha)))
(terpri)
(write (member-if #'evenp '(3 7 2 5/3 'a)))
(terpri)
(write (member-if-not #'numberp '(3 7 2 5/3 'a 'b 'c)))
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
(ZARA RIYAN NUHA)
(2 5/3 'A)
('A 'B 'C)
यूनियन सेट करें
फ़ंक्शन का संघ समूह आपको परीक्षण के आधार पर इन कार्यों के तर्क के रूप में प्रदान की गई दो सूचियों पर सेट यूनियन प्रदर्शन करने की अनुमति देता है।
इन कार्यों के वाक्य विन्यास निम्नलिखित हैं -
union list1 list2 &key :test :test-not :key
nunion list1 list2 &key :test :test-not :key
unionफ़ंक्शन दो सूची लेता है और दोनों सूची में मौजूद सभी तत्वों से युक्त एक नई सूची देता है। यदि डुप्लीकेशंस हैं, तो सदस्य की केवल एक प्रति लौटी सूची में रखी गई है।
nunion फ़ंक्शन समान ऑपरेशन करता है लेकिन तर्क सूचियों को नष्ट कर सकता है।
उदाहरण
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(setq set1 (union '(a b c) '(c d e)))
(setq set2 (union '(#(a b) #(5 6 7) #(f h))
'(#(5 6 7) #(a b) #(g h)) :test-not #'mismatch)
)
(setq set3 (union '(#(a b) #(5 6 7) #(f h))
'(#(5 6 7) #(a b) #(g h)))
)
(write set1)
(terpri)
(write set2)
(terpri)
(write set3)
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
(A B C D E)
(#(F H) #(5 6 7) #(A B) #(G H))
(#(A B) #(5 6 7) #(F H) #(5 6 7) #(A B) #(G H))
कृपया ध्यान दें
यूनियन फ़ंक्शन बिना अपेक्षा के काम नहीं करता है :test-not #'mismatchतीन वैक्टर की एक सूची के लिए तर्क। इसका कारण यह है, सूचियाँ कॉन्स कोशिकाओं से बनी होती हैं और हालाँकि मूल्य हमें स्पष्ट रूप से एक जैसे लगते हैंcdrकोशिकाओं का हिस्सा मेल नहीं खाता है, इसलिए वे LISP दुभाषिया / संकलक के समान नहीं हैं। यही कारण है; सूचियों का उपयोग करके बड़े सेटों को लागू करने की सलाह नहीं दी जाती है। यह छोटे सेट के लिए ठीक काम करता है।
अंतःकरण सेट करें
कार्यों का चौराहा समूह आपको एक परीक्षण के आधार पर इन कार्यों के तर्क के रूप में प्रदान की गई दो सूचियों पर प्रतिच्छेदन करने की अनुमति देता है।
इन कार्यों के वाक्य विन्यास निम्नलिखित हैं -
intersection list1 list2 &key :test :test-not :key
nintersection list1 list2 &key :test :test-not :key
ये फ़ंक्शन दो सूचियाँ लेते हैं और दोनों तर्क सूचियों में मौजूद सभी तत्वों से युक्त एक नई सूची लौटाते हैं। यदि या तो सूची में डुप्लिकेट प्रविष्टियाँ हैं, तो निरर्थक प्रविष्टियाँ परिणाम में दिखाई दे सकती हैं या नहीं।
उदाहरण
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(setq set1 (intersection '(a b c) '(c d e)))
(setq set2 (intersection '(#(a b) #(5 6 7) #(f h))
'(#(5 6 7) #(a b) #(g h)) :test-not #'mismatch)
)
(setq set3 (intersection '(#(a b) #(5 6 7) #(f h))
'(#(5 6 7) #(a b) #(g h)))
)
(write set1)
(terpri)
(write set2)
(terpri)
(write set3)
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
(C)
(#(A B) #(5 6 7))
NIL
चौराहे समारोह चौराहे का विनाशकारी संस्करण है, अर्थात, यह मूल सूचियों को नष्ट कर सकता है।
अंतर सेट करें
फ़ंक्शंस का सेट-फ़र्क समूह आपको एक परीक्षण के आधार पर इन फ़ंक्शंस के तर्क के रूप में प्रदान की गई दो सूचियों पर सेट अंतर करने की अनुमति देता है।
इन कार्यों के वाक्य विन्यास निम्नलिखित हैं -
set-difference list1 list2 &key :test :test-not :key
nset-difference list1 list2 &key :test :test-not :key
सेट-अंतर फ़ंक्शन पहली सूची के तत्वों की एक सूची देता है जो दूसरी सूची में प्रकट नहीं होती हैं।
उदाहरण
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(setq set1 (set-difference '(a b c) '(c d e)))
(setq set2 (set-difference '(#(a b) #(5 6 7) #(f h))
'(#(5 6 7) #(a b) #(g h)) :test-not #'mismatch)
)
(setq set3 (set-difference '(#(a b) #(5 6 7) #(f h))
'(#(5 6 7) #(a b) #(g h)))
)
(write set1)
(terpri)
(write set2)
(terpri)
(write set3)
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
(A B)
(#(F H))
(#(A B) #(5 6 7) #(F H))
आप सूचियों की सूची के रूप में, आम कोशिकाओं से पेड़ डेटा संरचनाओं का निर्माण कर सकते हैं।
वृक्ष संरचनाओं को लागू करने के लिए, आपको कार्यात्मक कोशिकाओं को डिजाइन करना होगा जो कि विशिष्ट कोशिकाओं में, विशिष्ट क्रम में, उदाहरण के लिए, प्री-ऑर्डर, इन-ऑर्डर और द्विआधारी पेड़ों के लिए पोस्ट-ऑर्डर के माध्यम से चलेंगे।
पेड़ों की सूची के रूप में
आइए हम कंस सेल से बने एक पेड़ की संरचना पर विचार करें जो सूचियों की निम्नलिखित सूची बनाती है -
((1 2) (3 4) (5 6))।
आरेखीय रूप से, इसे इस प्रकार व्यक्त किया जा सकता है -
LISP में ट्री फ़ंक्शंस
यद्यपि ज्यादातर आपको अपनी विशिष्ट आवश्यकता के अनुसार अपनी खुद की ट्री-फंक्शन्स लिखने की आवश्यकता होगी, LISP कुछ ट्री फ़ंक्शंस प्रदान करता है जिनका आप उपयोग कर सकते हैं।
सभी सूची कार्यों के अलावा, निम्नलिखित कार्य विशेष रूप से वृक्ष संरचनाओं पर काम करते हैं -
अनु क्रमांक। | समारोह विवरण |
---|---|
1 | copy-tree x और वैकल्पिक वीसीपी यह बुरा कोशिकाओं के पेड़ की एक प्रति देता है x। यह कार और सीडीआर दोनों दिशाओं की पुनरावृत्ति करता है। यदि x एक सामान्य सेल नहीं है, तो फ़ंक्शन केवल x अपरिवर्तित देता है। यदि वैकल्पिक vecp तर्क सही है, तो यह फ़ंक्शन वैक्टर (पुनरावर्ती) के साथ-साथ कॉन्स कोशिकाओं को भी कॉपी करता है। |
2 | tree-equal xy और कुंजी: परीक्षण: परीक्षण-नहीं: कुंजी यह बुरा कोशिकाओं के दो पेड़ों की तुलना करता है। यदि x और y दोनों कॉन्स सेल हैं, तो उनकी कारों और सीडीआर की तुलना पुनरावृत्ति से की जाती है। यदि न तो x और न ही y एक आम कोशिका है, तो उनकी तुलना eql से या निर्दिष्ट परीक्षण के अनुसार की जाती है। :, कुंजी फ़ंक्शन, यदि निर्दिष्ट किया गया है, दोनों पेड़ों के तत्वों पर लागू होता है। |
3 | subst नया पुराना पेड़ और कुंजी: परीक्षण: परीक्षण-नहीं: कुंजी यह पेड़ में नई वस्तु के साथ दी गई पुरानी वस्तु की घटनाओं को प्रतिस्थापित करता है, जो कि कंस कोशिकाओं का एक पेड़ है। |
4 | nsubst नया पुराना पेड़ और कुंजी: परीक्षण: परीक्षण-नहीं: कुंजी यह विकल्प के रूप में ही काम करता है, लेकिन यह मूल पेड़ को नष्ट कर देता है। |
5 | sublis अलिस्ट ट्री एंड की: टेस्ट: टेस्ट-नॉट: की यह subst तरह काम करता है, को छोड़कर यह एक संघ सूची लेता है कि alist पुराने नए जोड़े की। पेड़ के प्रत्येक तत्व (: कुंजी फ़ंक्शन, यदि कोई हो) को लागू करने के बाद, एलिस्ट की कारों के साथ तुलना की जाती है; यदि यह मेल खाता है, तो इसे संबंधित सीडीआर से बदल दिया जाता है। |
6 | nsublis अलिस्ट ट्री एंड की: टेस्ट: टेस्ट-नॉट: की यह सब्लिस के समान ही काम करता है, लेकिन एक विनाशकारी संस्करण है। |
उदाहरण 1
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(setq lst (list '(1 2) '(3 4) '(5 6)))
(setq mylst (copy-list lst))
(setq tr (copy-tree lst))
(write lst)
(terpri)
(write mylst)
(terpri)
(write tr)
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
((1 2) (3 4) (5 6))
((1 2) (3 4) (5 6))
((1 2) (3 4) (5 6))
उदाहरण 2
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(setq tr '((1 2 (3 4 5) ((7 8) (7 8 9)))))
(write tr)
(setq trs (subst 7 1 tr))
(terpri)
(write trs)
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
((1 2 (3 4 5) ((7 8) (7 8 9))))
((7 2 (3 4 5) ((7 8) (7 8 9))))
अपने खुद के पेड़ का निर्माण
आइए हम LISP में उपलब्ध सूची कार्यों का उपयोग करते हुए, अपना खुद का पेड़ बनाने की कोशिश करें।
पहले हमें एक नया नोड बनाते हैं जिसमें कुछ डेटा होता है
(defun make-tree (item)
"it creates a new node with item."
(cons (cons item nil) nil)
)
अगला हम पेड़ में एक बच्चा नोड जोड़ते हैं - यह दो पेड़ नोड्स ले जाएगा और पहले के बच्चे के रूप में दूसरा पेड़ जोड़ देगा।
(defun add-child (tree child)
(setf (car tree) (append (car tree) child))
tree)
यह फ़ंक्शन पहले बच्चे को दिए गए पेड़ को लौटाएगा - यह एक पेड़ का नोड लेगा और उस नोड के पहले बच्चे को वापस करेगा, या शून्य करेगा, अगर इस नोड में कोई बच्चा नोड नहीं है।
(defun first-child (tree)
(if (null tree)
nil
(cdr (car tree))
)
)
यह फ़ंक्शन दिए गए नोड के अगले सिबलिंग को लौटा देगा - यह एक ट्री नोड को तर्क के रूप में लेता है, और अगले सिबलिंग नोड, या शून्य के संदर्भ में रिटर्न देता है, यदि नोड में कोई भी नहीं है।
(defun next-sibling (tree)
(cdr tree)
)
अंत में हमें नोड में जानकारी वापस करने के लिए एक फ़ंक्शन की आवश्यकता है -
(defun data (tree)
(car (car tree))
)
उदाहरण
यह उदाहरण उपरोक्त क्रियाओं का उपयोग करता है -
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(defun make-tree (item)
"it creates a new node with item."
(cons (cons item nil) nil)
)
(defun first-child (tree)
(if (null tree)
nil
(cdr (car tree))
)
)
(defun next-sibling (tree)
(cdr tree)
)
(defun data (tree)
(car (car tree))
)
(defun add-child (tree child)
(setf (car tree) (append (car tree) child))
tree
)
(setq tr '((1 2 (3 4 5) ((7 8) (7 8 9)))))
(setq mytree (make-tree 10))
(write (data mytree))
(terpri)
(write (first-child tr))
(terpri)
(setq newtree (add-child tr mytree))
(terpri)
(write newtree)
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
10
(2 (3 4 5) ((7 8) (7 8 9)))
((1 2 (3 4 5) ((7 8) (7 8 9)) (10)))
हैश टेबल डेटा संरचना का एक संग्रह का प्रतिनिधित्व करता है key-and-valueजोड़े जो कुंजी के हैश कोड के आधार पर आयोजित किए जाते हैं। यह संग्रह में तत्वों तक पहुंचने के लिए कुंजी का उपयोग करता है।
एक हैश तालिका का उपयोग तब किया जाता है जब आपको कुंजी का उपयोग करके तत्वों तक पहुंचने की आवश्यकता होती है, और आप एक उपयोगी कुंजी मान की पहचान कर सकते हैं। हैश तालिका में प्रत्येक आइटम में एक कुंजी / मान युग्म है। संग्रह में आइटम तक पहुंचने के लिए कुंजी का उपयोग किया जाता है।
LISP में हैश टेबल बनाना
आम एलआईएसपी में, हैश टेबल एक सामान्य प्रयोजन संग्रह है। आप एक कुंजी या अनुक्रमित के रूप में मनमानी वस्तुओं का उपयोग कर सकते हैं।
जब आप किसी हैश तालिका में मान संग्रहीत करते हैं, तो आप एक कुंजी-मूल्य जोड़ी बनाते हैं, और इसे उस कुंजी के नीचे संग्रहीत करते हैं। बाद में आप उसी कुंजी का उपयोग करके हैश तालिका से मान पुनः प्राप्त कर सकते हैं। एक कुंजी के लिए प्रत्येक कुंजी मानचित्र, हालांकि आप एक कुंजी में एक नया मान संग्रहीत कर सकते हैं।
एलआईएसपी में हैश टेबल को तीन प्रकारों में वर्गीकृत किया जा सकता है, जिस तरह से कुंजी की तुलना की जा सकती है - eq, eql या बराबर। यदि LISP ऑब्जेक्ट्स पर हैश टेबल को हैश किया जाता है तो चाबियाँ eq या eql के साथ तुलना की जाती हैं। यदि पेड़ की संरचना पर हैश टेबल हैश होती है, तो इसकी तुलना बराबर उपयोग करके की जाएगी।
make-hash-tableहैश टेबल बनाने के लिए फंक्शन का उपयोग किया जाता है। इस कार्य के लिए सिंटैक्स है -
make-hash-table &key :test :size :rehash-size :rehash-threshold
कहाँ -
key तर्क कुंजी प्रदान करता है।
:testतर्क यह निर्धारित करता है कि कुंजियों की तुलना कैसे की जाती है - इसमें तीन मानों में से एक होना चाहिए # 'eq, #' eql, या # 'बराबर, या तीन प्रतीकों में से एक eq, eql, या समान। यदि निर्दिष्ट नहीं है, तो eql मान लिया गया है।
:sizeतर्क हैश तालिका का प्रारंभिक आकार सेट करता है। यह शून्य से अधिक पूर्णांक होना चाहिए।
:rehash-sizeतर्क निर्दिष्ट करता है कि हैश तालिका के आकार को बढ़ाने के लिए जब यह पूर्ण हो जाता है। यह शून्य से अधिक पूर्णांक हो सकता है, जो जोड़ने के लिए प्रविष्टियों की संख्या है, या यह 1 से अधिक फ्लोटिंग-पॉइंट संख्या हो सकती है, जो पुराने आकार के नए आकार का अनुपात है। इस तर्क के लिए डिफ़ॉल्ट मान कार्यान्वयन-निर्भर है।
:rehash-thresholdतर्क निर्दिष्ट करता है कि बढ़ने से पहले हैश तालिका को पूरा कैसे प्राप्त किया जा सकता है। यह शून्य से अधिक और पूर्णांक से कम पूर्णांक हो सकता है: rehash- आकार (जिस स्थिति में तालिका में बड़े होने पर इसे बढ़ाया जाएगा), या यह शून्य और 1. के बीच फ्लोटिंग-पॉइंट संख्या हो सकती है। इसके लिए डिफ़ॉल्ट मान तर्क कार्यान्वयन-निर्भर है।
आप मेक-हैश टेबल फ़ंक्शन को बिना किसी तर्क के भी कॉल कर सकते हैं।
आइटमों को पुनः प्राप्त करना और आइटम को हैश टेबल में जोड़ना
gethashफ़ंक्शन हैश तालिका से किसी आइटम को उसकी कुंजी खोजकर प्राप्त करता है। यदि यह कुंजी नहीं ढूंढता है, तो यह शून्य देता है।
इसके निम्नलिखित सिंटैक्स हैं -
gethash key hash-table &optional default
कहाँ -
कुंजी: संबद्ध कुंजी है
हैश-टेबल: खोजा जाने वाला हैश-टेबल है
डिफ़ॉल्ट: लौटाया जाने वाला मान है, यदि प्रविष्टि नहीं मिली है, जो शून्य है, यदि निर्दिष्ट नहीं है।
gethash फ़ंक्शन वास्तव में दो मान लौटाता है, दूसरा एक विधेय मूल्य है जो कि एक प्रविष्टि के पाए जाने पर सही है, और यदि कोई प्रविष्टि नहीं मिली तो गलत है।
किसी आइटम को हैश तालिका में जोड़ने के लिए, आप उपयोग कर सकते हैं setf साथ काम करते हैं gethash समारोह।
उदाहरण
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(setq empList (make-hash-table))
(setf (gethash '001 empList) '(Charlie Brown))
(setf (gethash '002 empList) '(Freddie Seal))
(write (gethash '001 empList))
(terpri)
(write (gethash '002 empList))
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
(CHARLIE BROWN)
(FREDDIE SEAL)
एक प्रविष्टि निकालना
remhashफ़ंक्शन हैश-टेबल में एक विशिष्ट कुंजी के लिए किसी भी प्रविष्टि को हटा देता है। यह एक विधेय है जो अगर वहाँ था या नहीं तो प्रवेश या असत्य था, यह सच है।
इस फ़ंक्शन का सिंटैक्स है -
remhash key hash-table
उदाहरण
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(setq empList (make-hash-table))
(setf (gethash '001 empList) '(Charlie Brown))
(setf (gethash '002 empList) '(Freddie Seal))
(setf (gethash '003 empList) '(Mark Mongoose))
(write (gethash '001 empList))
(terpri)
(write (gethash '002 empList))
(terpri)
(write (gethash '003 empList))
(remhash '003 empList)
(terpri)
(write (gethash '003 empList))
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
(CHARLIE BROWN)
(FREDDIE SEAL)
(MARK MONGOOSE)
NIL
मपश फशन
maphash फ़ंक्शन आपको हैश टेबल पर प्रत्येक कुंजी-मूल्य जोड़ी पर एक निर्दिष्ट फ़ंक्शन लागू करने की अनुमति देता है।
यह दो तर्क लेता है - फ़ंक्शन और एक हैश तालिका और हैश तालिका में प्रत्येक कुंजी / मान जोड़ी के लिए एक बार फ़ंक्शन को आमंत्रित करता है।
उदाहरण
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(setq empList (make-hash-table))
(setf (gethash '001 empList) '(Charlie Brown))
(setf (gethash '002 empList) '(Freddie Seal))
(setf (gethash '003 empList) '(Mark Mongoose))
(maphash #'(lambda (k v) (format t "~a => ~a~%" k v)) empList)
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
3 => (MARK MONGOOSE)
2 => (FREDDIE SEAL)
1 => (CHARLIE BROWN)
आम LISP कई इनपुट-आउटपुट फ़ंक्शन प्रदान करता है। हमने पहले ही आउटपुट के लिए प्रारूप फ़ंक्शन और प्रिंट फ़ंक्शन का उपयोग किया है। इस खंड में, हम LISP में प्रदान किए गए कुछ सबसे अधिक उपयोग किए जाने वाले इनपुट-आउटपुट कार्यों पर ध्यान देंगे।
इनपुट फ़ंक्शंस
निम्न तालिका LISP के सबसे अधिक इस्तेमाल किए जाने वाले इनपुट कार्यों को प्रदान करती है -
अनु क्रमांक। | समारोह विवरण |
---|---|
1 | read& वैकल्पिक इनपुट-स्ट्रीम ईओफ़-एरर-पी ईओफ़-मूल्य पुनरावर्ती-पी यह इनपुट-स्ट्रीम से एक लिस्प ऑब्जेक्ट के मुद्रित प्रतिनिधित्व में पढ़ता है, इसी लिस्प ऑब्जेक्ट बनाता है, और ऑब्जेक्ट को वापस करता है। |
2 | read-preserving-whitespace& वैकल्पिक इन-स्ट्रीम ईओफ़-एरर-पी ईओफ़-मूल्य पुनरावर्ती-पी इसका उपयोग कुछ विशेष स्थितियों में किया जाता है, जहां यह निर्धारित करना वांछनीय है कि किस चरित्र ने विस्तारित टोकन को समाप्त कर दिया। |
3 | read-line& वैकल्पिक इनपुट-स्ट्रीम ईओफ़-एरर-पी ईओफ़-मूल्य पुनरावर्ती-पी यह एक newline द्वारा समाप्त पाठ की एक पंक्ति में पढ़ता है। |
4 | read-char& वैकल्पिक इनपुट-स्ट्रीम ईओफ़-एरर-पी ईओफ़-मूल्य पुनरावर्ती-पी यह इनपुट-स्ट्रीम से एक वर्ण लेता है और इसे एक चरित्र ऑब्जेक्ट के रूप में लौटाता है। |
5 | unread-char चरित्र और वैकल्पिक इनपुट-धारा यह इनपुट-स्ट्रीम से सबसे हाल ही में पढ़े गए पात्र को इनपुट-स्ट्रीम के सामने रखता है। |
6 | peek-char& वैकल्पिक झांकना-प्रकार इनपुट-स्ट्रीम eof-error-p eof-value पुनरावर्ती-पी यह इनपुट-स्ट्रीम से पढ़ा जाने वाला अगला वर्ण देता है, वास्तव में इसे इनपुट स्ट्रीम से हटाए बिना। |
7 | listenऔर वैकल्पिक इनपुट-स्ट्रीम विधेय listen यह सच है कि अगर इनपुट-स्ट्रीम से कोई चरित्र तुरंत उपलब्ध है, और यदि नहीं तो गलत है। |
8 | read-char-no-hang& वैकल्पिक इनपुट-स्ट्रीम ईओफ़-एरर-पी ईओफ़-मूल्य पुनरावर्ती-पी यह समान है read-char, लेकिन अगर इसे एक चरित्र नहीं मिलता है, तो यह एक चरित्र की प्रतीक्षा नहीं करता है, लेकिन तुरंत शून्य देता है। |
9 | clear-inputऔर वैकल्पिक इनपुट-स्ट्रीम यह इनपुट-स्ट्रीम से जुड़े किसी भी बफर इनपुट को साफ करता है। |
10 | read-from-string स्ट्रिंग और वैकल्पिक ईओफ़-त्रुटि-पी ईओफ़-मूल्य और कुंजी: प्रारंभ: अंत: संरक्षित-व्हाट्सएप यह स्ट्रिंग के पात्रों को क्रमिक रूप से लेता है और एक LISP ऑब्जेक्ट बनाता है और ऑब्जेक्ट को लौटाता है। यह स्ट्रिंग में पहले वर्ण के सूचकांक को भी नहीं पढ़ता है, या स्ट्रिंग की लंबाई (या, लंबाई +1), जैसा कि मामला हो सकता है। |
1 1 | parse-integer स्ट्रिंग और कुंजी: प्रारंभ: अंत: मूलांक: जंक-अनुमत यह स्ट्रिंग सीमांकित के विकल्प की जांच करता है: प्रारंभ और: अंत (स्ट्रिंग की शुरुआत और अंत तक डिफ़ॉल्ट)। यह व्हॉट्सएप के पात्रों पर छोड़ देता है और फिर एक पूर्णांक को पार्स करने का प्रयास करता है। |
12 | read-byte बाइनरी-इनपुट-स्ट्रीम और वैकल्पिक ईओफ़-त्रुटि-पी ईओफ़-मूल्य यह बाइनरी-इनपुट-स्ट्रीम से एक बाइट पढ़ता है और इसे पूर्णांक के रूप में वापस करता है। |
कीबोर्ड से इनपुट पढ़ना
readफ़ंक्शन का उपयोग कीबोर्ड से इनपुट लेने के लिए किया जाता है। यह कोई तर्क नहीं ले सकता है।
उदाहरण के लिए, कोड स्निपेट पर विचार करें -
(write ( + 15.0 (read)))
मान लें कि उपयोगकर्ता STDIN इनपुट से 10.2 में प्रवेश करता है, तो यह वापस आ जाता है,
25.2
रीड फ़ंक्शन एक इनपुट स्ट्रीम से वर्ण पढ़ता है और लिस्प ऑब्जेक्ट्स के अभ्यावेदन के रूप में पार्स करके उनकी व्याख्या करता है।
उदाहरण
Main.lisp नाम से एक नया स्रोत कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें -
; the function AreaOfCircle
; calculates area of a circle
; when the radius is input from keyboard
(defun AreaOfCircle()
(terpri)
(princ "Enter Radius: ")
(setq radius (read))
(setq area (* 3.1416 radius radius))
(princ "Area: ")
(write area))
(AreaOfCircle)
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
Enter Radius: 5 (STDIN Input)
Area: 78.53999
उदाहरण
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(with-input-from-string (stream "Welcome to Tutorials Point!")
(print (read-char stream))
(print (read-char stream))
(print (read-char stream))
(print (read-char stream))
(print (read-char stream))
(print (read-char stream))
(print (read-char stream))
(print (read-char stream))
(print (read-char stream))
(print (read-char stream))
(print (peek-char nil stream nil 'the-end))
(values)
)
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
#\W
#\e
#\l
#\c
#\o
#\m
#\e
#\Space
#\t
#\o
#\Space
आउटपुट कार्य
LISP में सभी आउटपुट फ़ंक्शन आउटपुट-स्ट्रीम नामक एक वैकल्पिक तर्क लेते हैं , जहां आउटपुट भेजा जाता है। यदि उल्लेख या शून्य नहीं है, तो आउटपुट-स्ट्रीम डिफॉल्ट को वैरिएबल के मानक * मानक-आउटपुट * पर ले जाता है।
निम्न तालिका LISP के सबसे अधिक इस्तेमाल किए जाने वाले आउटपुट कार्यों को प्रदान करती है -
अनु क्रमांक। | समारोह और विवरण |
---|---|
1 | write ऑब्जेक्ट और कुंजी: स्ट्रीम: एस्केप: रेडिक्स: बेस: सर्कल: सुंदर: स्तर: लंबाई: मामला: जेनसम: सरणी write ऑब्जेक्ट और कुंजी: स्ट्रीम: एस्केप: रेडिक्स: बेस: सर्कल: सुंदर: स्तर: लंबाई: केस: जेनसम: सरणी: आसानी से: सही-मार्जिन: मिसर-चौड़ाई: लाइनें: प्रिंट-प्रेषण दोनों ऑब्जेक्ट द्वारा निर्दिष्ट आउटपुट स्ट्रीम पर लिखते हैं: स्ट्रीम, जो * मानक-आउटपुट * के मान को डिफॉल्ट करता है। अन्य मान मुद्रण के लिए निर्धारित वैश्विक वैरिएबल के लिए डिफ़ॉल्ट हैं। |
2 | prin1 ऑब्जेक्ट और वैकल्पिक आउटपुट-स्ट्रीम print ऑब्जेक्ट और वैकल्पिक आउटपुट-स्ट्रीम pprint ऑब्जेक्ट और वैकल्पिक आउटपुट-स्ट्रीम princ ऑब्जेक्ट और वैकल्पिक आउटपुट-स्ट्रीम ये सभी कार्य आउटपुट-स्ट्रीम में ऑब्जेक्ट के मुद्रित प्रतिनिधित्व को आउटपुट करते हैं । हालाँकि, निम्नलिखित अंतर हैं -
|
3 | write-to-string ऑब्जेक्ट एंड की : एस्केप: रेडिक्स: बेस: सर्कल: सुंदर: लेवल: लेंथ: केस: जेंसम: एरे write-to-string ऑब्जेक्ट और कुंजी: बच: मूलांक: आधार: वृत्त: सुंदर: स्तर: लंबाई: मामला: gensym: सरणी: आसानी से: सही-मार्जिन: कंजूस-चौड़ाई: लाइनें: pprint-dispatch prin1-to-string वस्तु princ-to-string वस्तु ऑब्जेक्ट को प्रभावी ढंग से मुद्रित किया जाता है और आउटपुट वर्णों को एक स्ट्रिंग में बनाया जाता है, जिसे वापस कर दिया जाता है। |
4 | write-char चरित्र और वैकल्पिक आउटपुट-स्ट्रीम यह चरित्र को आउटपुट-स्ट्रीम पर आउटपुट करता है, और चरित्र को लौटाता है। |
5 | write-string स्ट्रिंग और वैकल्पिक आउटपुट-स्ट्रीम और कुंजी: प्रारंभ: अंत यह निर्दिष्ट स्ट्रिंग के पात्रों लिखते स्ट्रिंग के लिए उत्पादन-स्ट्रीम। |
6 | write-line स्ट्रिंग और वैकल्पिक आउटपुट-स्ट्रीम और कुंजी: प्रारंभ: अंत यह राइट-स्ट्रिंग के समान कार्य करता है, लेकिन बाद में एक नई लाइन आउटपुट करता है। |
7 | terpriऔर वैकल्पिक आउटपुट-स्ट्रीम यह आउटपुट-स्ट्रीम के लिए एक नई लाइन आउटपुट करता है। |
8 | fresh-lineऔर वैकल्पिक आउटपुट-स्ट्रीम यह एक नई लाइन का आउटपुट तभी देता है जब स्ट्रीम पहले से ही लाइन में न हो। |
9 | finish-outputऔर वैकल्पिक आउटपुट-स्ट्रीम force-outputऔर वैकल्पिक आउटपुट-स्ट्रीम clear-outputऔर वैकल्पिक आउटपुट-स्ट्रीम
|
10 | write-byte पूर्णांक बाइनरी-आउटपुट-स्ट्रीम यह एक बाइट, पूर्णांक का मान लिखता है । |
उदाहरण
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
; this program inputs a numbers and doubles it
(defun DoubleNumber()
(terpri)
(princ "Enter Number : ")
(setq n1 (read))
(setq doubled (* 2.0 n1))
(princ "The Number: ")
(write n1)
(terpri)
(princ "The Number Doubled: ")
(write doubled)
)
(DoubleNumber)
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
Enter Number : 3456.78 (STDIN Input)
The Number: 3456.78
The Number Doubled: 6913.56
स्वरूपित आउटपुट
कार्यक्रम formatअच्छी तरह से स्वरूपित पाठ के उत्पादन के लिए प्रयोग किया जाता है। इसके निम्नलिखित सिंटैक्स हैं -
format destination control-string &rest arguments
कहाँ पे,
- गंतव्य मानक आउटपुट है
- नियंत्रण स्ट्रिंग उत्पादन और मुद्रण निर्देश होने के लिए वर्ण रखती है।
ए format directive एक टिल्ड (~), कॉमा से अलग किए गए वैकल्पिक उपसर्ग पैरामीटर, वैकल्पिक बृहदान्त्र (:) और एट-साइन (@) संशोधक होते हैं, और एक एकल वर्ण यह दर्शाता है कि यह किस प्रकार का निर्देश है।
उपसर्ग पैरामीटर आमतौर पर पूर्णांक होते हैं, वैकल्पिक रूप से हस्ताक्षरित दशमलव संख्या के रूप में नोट किए जाते हैं।
निम्न तालिका सामान्यतः उपयोग किए गए निर्देशों का संक्षिप्त विवरण प्रदान करती है -
अनु क्रमांक। | निर्देश और विवरण |
---|---|
1 | ~A ASCII के तर्कों के बाद है। |
2 | ~S इसके बाद एस-एक्सप्रेशंस है। |
3 | ~D दशमलव तर्कों के लिए। |
4 | ~B द्विआधारी तर्कों के लिए। |
5 | ~O अष्टक तर्कों के लिए। |
6 | ~X हेक्साडेसिमल तर्कों के लिए। |
7 | ~C चरित्र तर्क के लिए। |
8 | ~F फिक्स्ड-फॉर्मेट फ़्लोटिंग-पॉइंट तर्क के लिए। |
9 | ~E घातीय फ्लोटिंग-पॉइंट तर्क। |
10 | ~$ डॉलर और फ्लोटिंग पॉइंट तर्क। |
1 1 | ~% एक नई लाइन छपी है। |
12 | ~* अगला तर्क नजरअंदाज कर दिया जाता है। |
13 | ~? अविवेक। अगला तर्क एक स्ट्रिंग होना चाहिए, और एक के बाद एक सूची। |
उदाहरण
आइए हम एक वृत्त के क्षेत्रफल की गणना करने वाले कार्यक्रम को फिर से लिखें -
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(defun AreaOfCircle()
(terpri)
(princ "Enter Radius: ")
(setq radius (read))
(setq area (* 3.1416 radius radius))
(format t "Radius: = ~F~% Area = ~F" radius area)
)
(AreaOfCircle)
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
Enter Radius: 10.234 (STDIN Input)
Radius: = 10.234
Area = 329.03473
हमने इस बारे में चर्चा की है कि कैसे मानक इनपुट और आउटपुट को आम LISP द्वारा नियंत्रित किया जाता है। ये सभी कार्य पाठ और बाइनरी फाइलों में से पढ़ने और लिखने के लिए भी काम करते हैं। केवल अंतर इस मामले में है कि हम जिस स्ट्रीम का उपयोग करते हैं वह मानक इनपुट या आउटपुट नहीं है, बल्कि फाइलों से लिखने या पढ़ने के विशिष्ट उद्देश्य के लिए बनाई गई स्ट्रीम है।
इस अध्याय में हम देखेंगे कि LISP अपने डेटा स्टोरेज के लिए LISP कैसे बना सकता है, खोल सकता है, बंद कर सकता है।
एक फाइल बाइट्स के अनुक्रम का प्रतिनिधित्व करती है, इससे कोई फर्क नहीं पड़ता कि यह एक टेक्स्ट फाइल या बाइनरी फाइल है। यह अध्याय आपको फ़ाइल प्रबंधन के लिए महत्वपूर्ण कार्यों / मैक्रोज़ के माध्यम से ले जाएगा।
फाइलें खोलना
आप उपयोग कर सकते हैं openएक नई फ़ाइल बनाने के लिए या किसी मौजूदा फ़ाइल को खोलने के लिए कार्य करते हैं। यह एक फ़ाइल खोलने के लिए सबसे बुनियादी कार्य है। हालांकिwith-open-file आमतौर पर अधिक सुविधाजनक और अधिक सामान्यतः उपयोग किया जाता है, जैसा कि हम इस खंड में बाद में देखेंगे।
जब कोई फ़ाइल खोली जाती है, तो LISP वातावरण में इसका प्रतिनिधित्व करने के लिए एक स्ट्रीम ऑब्जेक्ट का निर्माण किया जाता है। स्ट्रीम पर सभी ऑपरेशन मूल रूप से फ़ाइल के संचालन के बराबर हैं।
के लिए सिंटैक्स open कार्य है -
open filename &key :direction :element-type :if-exists :if-does-not-exist :external-format
कहाँ पे,
फ़ाइल नाम तर्क फ़ाइल का नाम खोला या बनाया जा रहा है।
कीवर्ड तर्क धारा और त्रुटि हैंडलिंग तरीके से प्रकार निर्दिष्ट करें।
:direction कीवर्ड निर्दिष्ट करता है कि क्या स्ट्रीम को इनपुट, आउटपुट या दोनों को संभालना चाहिए, यह निम्नलिखित मान लेता है -
: इनपुट - इनपुट धाराओं के लिए (डिफ़ॉल्ट मान)
: आउटपुट - आउटपुट स्ट्रीम के लिए
: io - द्विदिश धाराओं के लिए
: जांच - सिर्फ एक फाइल के अस्तित्व की जाँच के लिए; स्ट्रीम को खोला जाता है और फिर बंद कर दिया जाता है।
:element-type स्ट्रीम के लिए लेनदेन की इकाई का प्रकार निर्दिष्ट करता है।
:if-existsतर्क निर्दिष्ट करने की क्रिया को निर्दिष्ट करता है: यदि: दिशा है: आउटपुट या: io और निर्दिष्ट नाम की एक फ़ाइल पहले से मौजूद है। यदि दिशा है: इनपुट या: जांच, इस तर्क को नजरअंदाज किया जाता है। यह निम्न मान लेता है -
: त्रुटि - यह एक त्रुटि का संकेत देती है।
: नया-संस्करण - यह एक ही नाम लेकिन बड़े संस्करण संख्या के साथ एक नई फ़ाइल बनाता है।
: नाम बदलें - यह मौजूदा फ़ाइल का नाम बदल देता है।
: नाम बदलें और हटाएं - यह मौजूदा फ़ाइल का नाम बदल देता है और फिर इसे हटा देता है।
: परिशिष्ट - यह मौजूदा फ़ाइल को जोड़ता है।
: सुपरडेड - यह मौजूदा फाइल को सुपरकोड करता है।
nil - यह एक फ़ाइल या यहां तक कि एक स्ट्रीम नहीं बनाता है जो विफलता का संकेत देने के लिए केवल nil देता है।
:if-does-not-existयदि निर्दिष्ट नाम की कोई फ़ाइल पहले से मौजूद नहीं है, तो तर्क कार्रवाई करने के लिए निर्दिष्ट करता है। यह निम्न मान लेता है -
: त्रुटि - यह एक त्रुटि का संकेत देती है।
: create - यह निर्दिष्ट नाम के साथ एक खाली फ़ाइल बनाता है और फिर इसका उपयोग करता है।
nil - यह एक फ़ाइल या एक स्ट्रीम भी नहीं बनाता है, बल्कि इसके बजाय केवल nil को विफलता का संकेत देता है।
:external-format तर्क फाइलों में पात्रों का प्रतिनिधित्व करने के लिए कार्यान्वयन-मान्यता प्राप्त योजना को निर्दिष्ट करता है।
उदाहरण के लिए, आप myfile.txt नामक फ़ाइल को / tmp फ़ोल्डर में संग्रहीत कर सकते हैं -
(open "/tmp/myfile.txt")
फाइलों से लिखना और पढ़ना
with-open-fileरीड / राइट ट्रांजेक्शन से जुड़े स्ट्रीम वैरिएबल का उपयोग करके किसी फाइल में पढ़ने या लिखने की अनुमति देता है। एक बार काम पूरा हो जाने के बाद, यह फ़ाइल को अपने आप बंद कर देता है। यह उपयोग करने के लिए बेहद सुविधाजनक है।
इसके निम्नलिखित सिंटैक्स हैं -
with-open-file (stream filename {options}*)
{declaration}* {form}*
फ़ाइल नाम खोला जाने वाली फ़ाइल का नाम है; यह एक स्ट्रिंग, एक pathname, या एक स्ट्रीम हो सकता है।
विकल्पों समारोह खुला करने के लिए कीवर्ड तर्क के रूप में ही कर रहे हैं।
उदाहरण 1
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(with-open-file (stream "/tmp/myfile.txt" :direction :output)
(format stream "Welcome to Tutorials Point!")
(terpri stream)
(format stream "This is a tutorials database")
(terpri stream)
(format stream "Submit your Tutorials, White Papers and Articles into our Tutorials Directory.")
)
कृपया ध्यान दें कि पिछले अध्याय में चर्चा किए गए सभी इनपुट-आउटपुट फ़ंक्शंस, जैसे कि, टेरीपरी और फॉर्मेट हमारे द्वारा बनाई गई फ़ाइल में लिखने के लिए काम कर रहे हैं।
जब आप कोड निष्पादित करते हैं, तो यह कुछ भी वापस नहीं करता है; हालाँकि, हमारा डेटा फ़ाइल में लिखा गया है। :direction :output कीवर्ड हमें ऐसा करने की अनुमति देते हैं।
हालाँकि, हम इस फ़ाइल से पढ़ सकते हैं read-line समारोह।
उदाहरण 2
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(let ((in (open "/tmp/myfile.txt" :if-does-not-exist nil)))
(when in
(loop for line = (read-line in nil)
while line do (format t "~a~%" line))
(close in)
)
)
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
Welcome to Tutorials Point!
This is a tutorials database
Submit your Tutorials, White Papers and Articles into our Tutorials Directory.
फाइल बंद करना
close फ़ंक्शन एक स्ट्रीम बंद कर देता है।
संरचनाएं उपयोगकर्ता-परिभाषित डेटा प्रकारों में से एक हैं, जो आपको विभिन्न प्रकार के डेटा आइटम को संयोजित करने की अनुमति देता है।
एक रिकॉर्ड का प्रतिनिधित्व करने के लिए संरचनाओं का उपयोग किया जाता है। मान लीजिए कि आप किसी लाइब्रेरी में अपनी पुस्तकों पर नज़र रखना चाहते हैं। आप प्रत्येक पुस्तक के बारे में निम्नलिखित विशेषताओं को ट्रैक करना चाहते हैं -
- Title
- Author
- Subject
- बुक आईडी
एक संरचना को परिभाषित करना
defstructएलआईएसपी में मैक्रो आपको एक सार रिकॉर्ड संरचना को परिभाषित करने की अनुमति देता है। defstruct बयान एक नए डेटा प्रकार को परिभाषित करता है, जिसमें आपके कार्यक्रम के लिए एक से अधिक सदस्य होते हैं।
के प्रारूप पर चर्चा करने के लिए defstructमैक्रो, हमें पुस्तक संरचना की परिभाषा लिखते हैं। हम पुस्तक संरचना को इस प्रकार परिभाषित कर सकते हैं -
(defstruct book
title
author
subject
book-id
)
कृपया ध्यान दें
उपरोक्त घोषणा चार के साथ एक पुस्तक संरचना बनाती है named components. इसलिए बनाई गई प्रत्येक पुस्तक इस संरचना का एक उद्देश्य होगी।
यह पुस्तक-शीर्षक, पुस्तक-लेखक, पुस्तक-विषय और पुस्तक-पुस्तक-आईडी नामक चार कार्यों को परिभाषित करता है, जो एक तर्क, एक पुस्तक संरचना को ले जाएगा, और पुस्तक के शीर्षक, लेखक, विषय और पुस्तक-आईडी को वापस कर देगा वस्तु। इन कार्यों को कहा जाता हैaccess functions.
प्रतीक पुस्तक एक डेटा प्रकार बन जाती है और आप इसका उपयोग करके जांच कर सकते हैं typep विधेय।
नाम से एक निहित कार्य भी होगा book-p, जो एक विधेय है और सत्य होगा यदि इसका तर्क एक किताब है और अन्यथा गलत है।
नाम का एक और निहित कार्य make-book बनाया जाएगा, जो एक है constructor, जो, जब आह्वान किया जाता है, चार घटकों के साथ एक डेटा संरचना बनाएगा, जो एक्सेस फ़ंक्शंस के साथ उपयोग के लिए उपयुक्त होगा।
#S syntax एक संरचना को संदर्भित करता है, और आप इसे एक किताब के उदाहरणों को पढ़ने या प्रिंट करने के लिए उपयोग कर सकते हैं।
एक तर्क की कॉपी-बुक नामक एक निहित फ़ंक्शन को भी परिभाषित किया गया है। यह एक पुस्तक ऑब्जेक्ट लेता है और एक अन्य पुस्तक ऑब्जेक्ट बनाता है, जो पहले वाले की एक प्रति है। इस फ़ंक्शन को कहा जाता हैcopier function.
आप उपयोग कर सकते हैं setf उदाहरण के लिए, किसी पुस्तक के घटकों को बदलना
(setf (book-book-id book3) 100)
उदाहरण
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(defstruct book
title
author
subject
book-id
)
( setq book1 (make-book :title "C Programming"
:author "Nuha Ali"
:subject "C-Programming Tutorial"
:book-id "478")
)
( setq book2 (make-book :title "Telecom Billing"
:author "Zara Ali"
:subject "C-Programming Tutorial"
:book-id "501")
)
(write book1)
(terpri)
(write book2)
(setq book3( copy-book book1))
(setf (book-book-id book3) 100)
(terpri)
(write book3)
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
#S(BOOK :TITLE "C Programming" :AUTHOR "Nuha Ali" :SUBJECT "C-Programming Tutorial" :BOOK-ID "478")
#S(BOOK :TITLE "Telecom Billing" :AUTHOR "Zara Ali" :SUBJECT "C-Programming Tutorial" :BOOK-ID "501")
#S(BOOK :TITLE "C Programming" :AUTHOR "Nuha Ali" :SUBJECT "C-Programming Tutorial" :BOOK-ID 100)
प्रोग्रामिंग भाषाओं के सामान्य शब्द में, एक पैकेज को दूसरे से अलग नामों के एक सेट को रखने का एक तरीका प्रदान करने के लिए डिज़ाइन किया गया है। एक पैकेज में घोषित प्रतीक दूसरे में घोषित समान प्रतीकों के साथ संघर्ष नहीं करेंगे। इस तरह से पैकेज स्वतंत्र कोड मॉड्यूल के बीच नामकरण संघर्ष को कम करते हैं।
LISP रीडर उन सभी प्रतीकों की एक तालिका को बनाए रखता है जो उसने पाया है। जब यह एक नया वर्ण अनुक्रम पाता है, तो यह एक नया प्रतीक बनाता है और प्रतीक तालिका में संग्रहीत करता है। इस तालिका को पैकेज कहा जाता है।
वर्तमान पैकेज को विशेष चर * पैकेज * द्वारा संदर्भित किया जाता है।
LISP में दो पूर्वनिर्धारित पैकेज हैं -
common-lisp - इसमें परिभाषित सभी कार्यों और चर के प्रतीक हैं।
common-lisp-user- यह आम-लिस्प पैकेज और संपादन और डीबगिंग टूल के साथ अन्य सभी पैकेजों का उपयोग करता है; इसे संक्षेप में cl-user कहा जाता है
पैकेज कार्य LISP में
निम्न तालिका पैकेज बनाने, उपयोग करने और हेरफेर करने के लिए उपयोग किए जाने वाले सबसे अधिक उपयोग किए जाने वाले कार्य प्रदान करती है -
अनु क्रमांक। | समारोह और विवरण |
---|---|
1 | make-package पैकेज-नाम और कुंजी: उपनाम: उपयोग यह निर्दिष्ट पैकेज नाम के साथ एक नया पैकेज बनाता है और लौटाता है। |
2 | in-package पैकेज-नाम और कुंजी: उपनाम: उपयोग पैकेज करंट बनाता है। |
3 | in-package नाम यह मैक्रो * पैकेज * नाम के पैकेज पर सेट होने का कारण बनता है, जो एक प्रतीक या स्ट्रिंग होना चाहिए। |
4 | find-package नाम यह एक पैकेज की खोज करता है। उस नाम या उपनाम वाला पैकेज लौटा दिया गया है; यदि ऐसा कोई पैकेज मौजूद नहीं है, तो खोज-पैकेज रिटर्न शून्य है। |
5 | rename-package पैकेज नया नाम और वैकल्पिक नए उपनाम यह एक पैकेज का नाम बदल देता है। |
6 | list-all-packages यह फ़ंक्शन उन सभी पैकेजों की सूची देता है जो वर्तमान में लिस्प प्रणाली में मौजूद हैं। |
7 | delete-package पैकेज यह एक पैकेज को हटाता है। |
एक LISP पैकेज बनाना
defpackageफ़ंक्शन का उपयोग उपयोगकर्ता परिभाषित पैकेज बनाने के लिए किया जाता है। इसके निम्नलिखित सिंटैक्स हैं -
(defpackage :package-name
(:use :common-lisp ...)
(:export :symbol1 :symbol2 ...)
)
कहाँ पे,
पैकेज-नाम पैकेज का नाम है।
: उपयोग कीवर्ड उन पैकेजों को निर्दिष्ट करता है जिन्हें इस पैकेज की आवश्यकता होती है, अर्थात, पैकेज जो इस पैकेज में कोड द्वारा उपयोग किए जाने वाले कार्यों को परिभाषित करते हैं।
: निर्यात कीवर्ड उन प्रतीकों को निर्दिष्ट करता है जो इस पैकेज में बाहरी हैं।
make-packageफंक्शन का उपयोग पैकेज बनाने के लिए भी किया जाता है। इस फ़ंक्शन का सिंटैक्स है -
make-package package-name &key :nicknames :use
तर्कों और खोजशब्दों का पहले जैसा ही अर्थ है।
पैकेज का उपयोग करना
एक बार जब आप एक पैकेज बना लेते हैं, तो आप इस पैकेज में वर्तमान पैकेज का उपयोग करके कोड का उपयोग कर सकते हैं। in-package मैक्रो वातावरण में एक पैकेज करंट बनाता है।
उदाहरण
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(make-package :tom)
(make-package :dick)
(make-package :harry)
(in-package tom)
(defun hello ()
(write-line "Hello! This is Tom's Tutorials Point")
)
(hello)
(in-package dick)
(defun hello ()
(write-line "Hello! This is Dick's Tutorials Point")
)
(hello)
(in-package harry)
(defun hello ()
(write-line "Hello! This is Harry's Tutorials Point")
)
(hello)
(in-package tom)
(hello)
(in-package dick)
(hello)
(in-package harry)
(hello)
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
Hello! This is Tom's Tutorials Point
Hello! This is Dick's Tutorials Point
Hello! This is Harry's Tutorials Point
पैकेज हटाना
delete-packageमैक्रो आपको एक पैकेज को हटाने की अनुमति देता है। निम्न उदाहरण यह प्रदर्शित करता है -
उदाहरण
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(make-package :tom)
(make-package :dick)
(make-package :harry)
(in-package tom)
(defun hello ()
(write-line "Hello! This is Tom's Tutorials Point")
)
(in-package dick)
(defun hello ()
(write-line "Hello! This is Dick's Tutorials Point")
)
(in-package harry)
(defun hello ()
(write-line "Hello! This is Harry's Tutorials Point")
)
(in-package tom)
(hello)
(in-package dick)
(hello)
(in-package harry)
(hello)
(delete-package tom)
(in-package tom)
(hello)
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
Hello! This is Tom's Tutorials Point
Hello! This is Dick's Tutorials Point
Hello! This is Harry's Tutorials Point
*** - EVAL: variable TOM has no value
सामान्य एलआईएसपी शब्दावली में, अपवाद को स्थितियां कहा जाता है।
वास्तव में, पारंपरिक प्रोग्रामिंग भाषाओं में अपवादों की तुलना में स्थितियां अधिक सामान्य हैं, क्योंकि ए condition किसी भी घटना, त्रुटि या नहीं का प्रतिनिधित्व करता है, जो फ़ंक्शन कॉल स्टैक के विभिन्न स्तरों को प्रभावित कर सकता है।
LISP में कंडीशन हैंडलिंग मैकेनिज्म, ऐसी स्थितियों को इस तरह से हैंडल करता है कि स्थितियों का उपयोग चेतावनी को संकेत देने के लिए किया जाता है (चेतावनी को प्रिंट करके कहना) जबकि कॉल स्टैक पर ऊपरी स्तर का कोड अपना काम जारी रख सकता है।
एलआईएसपी में स्थिति से निपटने की प्रणाली के तीन भाग हैं -
- एक स्थिति का संकेत
- हालत को संभालना
- प्रक्रिया को पुनरारंभ करें
एक शर्त संभालना
आइए हम यहां अवधारणाओं को समझाने के लिए शून्य स्थिति से विभाजित होने वाली स्थिति से निपटने का एक उदाहरण लेते हैं।
किसी शर्त को संभालने के लिए आपको निम्नलिखित कदम उठाने होंगे -
Define the Condition - "एक शर्त एक ऐसी वस्तु है जिसका वर्ग स्थिति की सामान्य प्रकृति को दर्शाता है और जिसका उदाहरण डेटा उन विशेष परिस्थितियों के विवरण के बारे में जानकारी देता है जो स्थिति को संकेतित करते हैं"।
परिभाषित-स्थिति मैक्रो का उपयोग किसी स्थिति को परिभाषित करने के लिए किया जाता है, जिसमें निम्न सिंटैक्स होता है -
(define-condition condition-name (error) ((text :initarg :text :reader text)) )
नई कंडीशन ऑब्जेक्ट्स MAKE-CONDITION मैक्रो के साथ बनाई गई हैं, जो कि इसके आधार पर नई कंडीशन के स्लॉट्स को इनिशियलाइज़ करती हैं :initargs बहस।
हमारे उदाहरण में, निम्नलिखित कोड हालत को परिभाषित करता है -
(define-condition on-division-by-zero (error) ((message :initarg :message :reader message)) )
Writing the Handlers- एक कंडीशन हैंडलर एक कोड होता है, जिसका उपयोग उस स्थिति के संकेत के लिए किया जाता है। यह आम तौर पर उच्च स्तर के कार्यों में से एक में लिखा जाता है जो इर्रिटिंग फ़ंक्शन को कहते हैं। जब किसी स्थिति का संकेत दिया जाता है, तो सिग्नलिंग तंत्र स्थिति के वर्ग के आधार पर एक उपयुक्त हैंडलर की खोज करता है।
प्रत्येक हैंडलर में शामिल हैं -
- प्रकार निर्दिष्ट करें, यह इंगित करता है कि यह किस प्रकार की स्थिति को संभाल सकता है
- एक फ़ंक्शन जो एकल तर्क लेता है, शर्त
जब एक स्थिति का संकेत दिया जाता है, तो सिग्नलिंग तंत्र सबसे हाल ही में स्थापित हैंडलर को ढूंढता है जो कि हालत प्रकार के साथ संगत है और इसके फ़ंक्शन को कॉल करता है।
स्थूल handler-caseएक शर्त हैंडलर स्थापित करता है। हैंडलर-केस का मूल रूप -
(handler-case expression error-clause*)
जहां, प्रत्येक त्रुटि क्लॉज फॉर्म का है -
condition-type ([var]) code)
Restarting Phase
यह वह कोड है जो वास्तव में त्रुटियों से आपके कार्यक्रम को पुन: प्राप्त करता है, और स्थिति संचालकों को एक उपयुक्त पुनरारंभ को लागू करके एक स्थिति को संभाल सकता है। पुनरारंभ कोड आम तौर पर मध्य-स्तर या निम्न-स्तर के कार्यों में होता है और स्थिति संचालकों को आवेदन के ऊपरी स्तरों में रखा जाता है।
handler-bindमैक्रो आपको पुनरारंभ फ़ंक्शन प्रदान करने की अनुमति देता है, और आपको फ़ंक्शन कॉल स्टैक को अनइंस्टॉल किए बिना निचले स्तर के फ़ंक्शन पर जारी रखने की अनुमति देता है। दूसरे शब्दों में, नियंत्रण का प्रवाह अभी भी निचले स्तर के कार्य में होगा।
का मूल रूप handler-bind इस प्रकार है -
(handler-bind (binding*) form*)
जहां प्रत्येक बंधन निम्नलिखित की सूची है -
- एक शर्त प्रकार
- एक तर्क का एक हैंडलर कार्य
invoke-restart मैक्रो तर्क के रूप में निर्दिष्ट नाम के साथ सबसे हाल ही में बाध्य पुनरारंभ फ़ंक्शन को ढूंढता है और आमंत्रित करता है।
आपके पास कई पुनरारंभ हो सकते हैं।
उदाहरण
इस उदाहरण में, हम डिवीजन-फंक्शन नामक एक फ़ंक्शन लिखकर उपरोक्त अवधारणाओं को प्रदर्शित करते हैं, जो कि डिविज़न तर्क शून्य होने पर त्रुटि स्थिति पैदा करेगा। हमारे पास तीन अनाम कार्य हैं जो इससे बाहर आने के तीन तरीके प्रदान करते हैं - एक मान 1 लौटाकर, एक भाजक 2 भेजकर और पुनर्गणना करके, या 1 लौटाकर।
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(define-condition on-division-by-zero (error)
((message :initarg :message :reader message))
)
(defun handle-infinity ()
(restart-case
(let ((result 0))
(setf result (division-function 10 0))
(format t "Value: ~a~%" result)
)
(just-continue () nil)
)
)
(defun division-function (value1 value2)
(restart-case
(if (/= value2 0)
(/ value1 value2)
(error 'on-division-by-zero :message "denominator is zero")
)
(return-zero () 0)
(return-value (r) r)
(recalc-using (d) (division-function value1 d))
)
)
(defun high-level-code ()
(handler-bind
(
(on-division-by-zero
#'(lambda (c)
(format t "error signaled: ~a~%" (message c))
(invoke-restart 'return-zero)
)
)
(handle-infinity)
)
)
)
(handler-bind
(
(on-division-by-zero
#'(lambda (c)
(format t "error signaled: ~a~%" (message c))
(invoke-restart 'return-value 1)
)
)
)
(handle-infinity)
)
(handler-bind
(
(on-division-by-zero
#'(lambda (c)
(format t "error signaled: ~a~%" (message c))
(invoke-restart 'recalc-using 2)
)
)
)
(handle-infinity)
)
(handler-bind
(
(on-division-by-zero
#'(lambda (c)
(format t "error signaled: ~a~%" (message c))
(invoke-restart 'just-continue)
)
)
)
(handle-infinity)
)
(format t "Done."))
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
error signaled: denominator is zero
Value: 1
error signaled: denominator is zero
Value: 5
error signaled: denominator is zero
Done.
जैसा कि ऊपर चर्चा की गई है, 'कंडीशन सिस्टम' के अलावा, कॉमन एलआईएसपी विभिन्न कार्यों को भी प्रदान करता है जिन्हें त्रुटि के संकेत के लिए बुलाया जा सकता है। एक त्रुटि से निपटने, जब संकेत दिया जाता है, हालांकि, कार्यान्वयन-निर्भर है।
LISP में त्रुटि सिग्नलिंग कार्य
निम्न तालिका आम तौर पर चेतावनी, ब्रेक, गैर-घातक और घातक त्रुटियों को इंगित करने वाले उपयोग किए गए फ़ंक्शन प्रदान करती है।
उपयोगकर्ता प्रोग्राम एक त्रुटि संदेश (एक स्ट्रिंग) निर्दिष्ट करता है। फ़ंक्शन इस संदेश को संसाधित करते हैं और इसे उपयोगकर्ता को प्रदर्शित नहीं कर सकते हैं / कर सकते हैं।
त्रुटि संदेशों को लागू करके निर्माण किया जाना चाहिए format फ़ंक्शन, में या तो शुरुआत या अंत में एक newline वर्ण नहीं होना चाहिए, और त्रुटि को इंगित करने की आवश्यकता नहीं है, क्योंकि LISP सिस्टम अपनी पसंदीदा शैली के अनुसार इनकी देखभाल करेगा।
अनु क्रमांक। | समारोह और विवरण |
---|---|
1 | error प्रारूप-स्ट्रिंग और बाकी args यह एक घातक त्रुटि का संकेत देता है। इस तरह की त्रुटि से जारी रखना असंभव है; इस प्रकार त्रुटि कभी भी अपने कॉलर पर वापस नहीं आएगी। |
2 | cerror जारी-प्रारूप-स्ट्रिंग त्रुटि-प्रारूप-स्ट्रिंग और बाकी args यह एक त्रुटि का संकेत देता है और डीबगर में प्रवेश करता है। हालाँकि, यह त्रुटि को हल करने के बाद प्रोग्राम को डीबगर से जारी रखने की अनुमति देता है। |
3 | warn प्रारूप-स्ट्रिंग और बाकी args यह एक त्रुटि संदेश प्रिंट करता है लेकिन आम तौर पर डीबगर में नहीं जाता है |
4 | breakऔर वैकल्पिक प्रारूप-स्ट्रिंग और बाकी args यह संदेश को प्रिंट करता है और प्रोग्रामर एरर-हैंडलिंग सुविधाओं द्वारा अवरोधन की किसी भी संभावना की अनुमति के बिना सीधे डिबगर में चला जाता है |
उदाहरण
इस उदाहरण में, भाज्य फ़ंक्शन किसी संख्या के भाज्य की गणना करता है; हालाँकि, यदि तर्क नकारात्मक है, तो यह एक त्रुटि स्थिति को बढ़ाता है।
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(defun factorial (x)
(cond ((or (not (typep x 'integer)) (minusp x))
(error "~S is a negative number." x))
((zerop x) 1)
(t (* x (factorial (- x 1))))
)
)
(write(factorial 5))
(terpri)
(write(factorial -1))
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
120
*** - -1 is a negative number.
आम एलआईएसपी ने कुछ दशकों के दौरान ऑब्जेक्ट-ओरिएंटेड प्रोग्रामिंग को आगे बढ़ाया। हालाँकि, इसे ऑब्जेक्ट-ओरिएंटेशन बाद के चरण में शामिल किया गया था।
परिभाषित करने वाली कक्षाएं
defclassमैक्रो उपयोगकर्ता-परिभाषित कक्षाएं बनाने की अनुमति देता है। यह एक वर्ग को डेटा प्रकार के रूप में स्थापित करता है। इसके निम्नलिखित सिंटैक्स हैं -
(defclass class-name (superclass-name*)
(slot-description*)
class-option*))
स्लॉट वैरिएबल होते हैं जो डेटा, या फ़ील्ड को स्टोर करते हैं।
एक स्लॉट-विवरण में फ़ॉर्म (स्लॉट-नाम स्लॉट-विकल्प *) होता है, जहां प्रत्येक विकल्प एक कीवर्ड होता है, जिसके बाद एक नाम, अभिव्यक्ति और अन्य विकल्प होते हैं। सबसे अधिक इस्तेमाल किया स्लॉट विकल्प हैं -
:accessor समारोह के नाम
:initform अभिव्यक्ति
:initarg प्रतीक
उदाहरण के लिए, आइए एक बॉक्स क्लास को परिभाषित करें, जिसमें तीन स्लॉट्स की लंबाई, चौड़ाई और ऊँचाई हो।
(defclass Box ()
(length
breadth
height)
)
एक खांचे तक पहुंच और पढ़ना / नियंत्रण प्रदान करना
जब तक स्लॉट में ऐसे मान नहीं होते जिन्हें एक्सेस किया जा सकता है, पढ़ा या लिखा जा सकता है, तब तक कक्षाएं बहुत बेकार हैं।
आप निर्दिष्ट कर सकते हैं accessorsप्रत्येक स्लॉट के लिए जब आप एक वर्ग को परिभाषित करते हैं। उदाहरण के लिए, हमारी बॉक्स क्लास लें -
(defclass Box ()
((length :accessor length)
(breadth :accessor breadth)
(height :accessor height)
)
)
आप अलग से भी निर्दिष्ट कर सकते हैं accessor एक स्लॉट पढ़ने और लिखने के लिए नाम।
(defclass Box ()
((length :reader get-length :writer set-length)
(breadth :reader get-breadth :writer set-breadth)
(height :reader get-height :writer set-height)
)
)
एक कक्षा का उदाहरण बनाना
सामान्य कार्य make-instance एक वर्ग का एक नया उदाहरण बनाता है और देता है।
इसके निम्नलिखित सिंटैक्स हैं -
(make-instance class {initarg value}*)
उदाहरण
हम तीन स्लॉट, लंबाई, चौड़ाई और ऊंचाई के साथ एक बॉक्स क्लास बनाते हैं। हम इन क्षेत्रों में मान सेट करने के लिए तीन स्लॉट एक्सेसरों का उपयोग करेंगे।
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(defclass box ()
((length :accessor box-length)
(breadth :accessor box-breadth)
(height :accessor box-height)
)
)
(setf item (make-instance 'box))
(setf (box-length item) 10)
(setf (box-breadth item) 10)
(setf (box-height item) 5)
(format t "Length of the Box is ~d~%" (box-length item))
(format t "Breadth of the Box is ~d~%" (box-breadth item))
(format t "Height of the Box is ~d~%" (box-height item))
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
Length of the Box is 10
Breadth of the Box is 10
Height of the Box is 5
कक्षा पद्धति को परिभाषित करना
defmethodमैक्रो आपको कक्षा के अंदर एक विधि को परिभाषित करने की अनुमति देता है। निम्नलिखित उदाहरण हमारे बॉक्स वर्ग का विस्तार करता है जिसमें मात्रा नाम की एक विधि शामिल है।
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(defclass box ()
((length :accessor box-length)
(breadth :accessor box-breadth)
(height :accessor box-height)
(volume :reader volume)
)
)
; method calculating volume
(defmethod volume ((object box))
(* (box-length object) (box-breadth object)(box-height object))
)
;setting the values
(setf item (make-instance 'box))
(setf (box-length item) 10)
(setf (box-breadth item) 10)
(setf (box-height item) 5)
; displaying values
(format t "Length of the Box is ~d~%" (box-length item))
(format t "Breadth of the Box is ~d~%" (box-breadth item))
(format t "Height of the Box is ~d~%" (box-height item))
(format t "Volume of the Box is ~d~%" (volume item))
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
Length of the Box is 10
Breadth of the Box is 10
Height of the Box is 5
Volume of the Box is 500
विरासत
LISP आपको किसी ऑब्जेक्ट को किसी अन्य ऑब्जेक्ट के संदर्भ में परिभाषित करने की अनुमति देता है। यह कहा जाता हैinheritance.आप नई या अलग-अलग विशेषताओं को जोड़कर एक व्युत्पन्न वर्ग बना सकते हैं। व्युत्पन्न वर्ग को मूल वर्ग की कार्यात्मकता विरासत में मिलती है।
निम्नलिखित उदाहरण यह बताते हैं -
उदाहरण
Main.lisp नाम से एक नया सोर्स कोड फ़ाइल बनाएँ और उसमें निम्न कोड टाइप करें।
(defclass box ()
((length :accessor box-length)
(breadth :accessor box-breadth)
(height :accessor box-height)
(volume :reader volume)
)
)
; method calculating volume
(defmethod volume ((object box))
(* (box-length object) (box-breadth object)(box-height object))
)
;wooden-box class inherits the box class
(defclass wooden-box (box)
((price :accessor box-price)))
;setting the values
(setf item (make-instance 'wooden-box))
(setf (box-length item) 10)
(setf (box-breadth item) 10)
(setf (box-height item) 5)
(setf (box-price item) 1000)
; displaying values
(format t "Length of the Wooden Box is ~d~%" (box-length item))
(format t "Breadth of the Wooden Box is ~d~%" (box-breadth item))
(format t "Height of the Wooden Box is ~d~%" (box-height item))
(format t "Volume of the Wooden Box is ~d~%" (volume item))
(format t "Price of the Wooden Box is ~d~%" (box-price item))
जब आप कोड निष्पादित करते हैं, तो यह निम्न परिणाम देता है -
Length of the Wooden Box is 10
Breadth of the Wooden Box is 10
Height of the Wooden Box is 5
Volume of the Wooden Box is 500
Price of the Wooden Box is 1000