मैं हास्केल के लिए एक नवागंतुक हूं और वर्तमान में रियल वर्ल्ड हास्केल के माध्यम से जा रहा हूं। पुस्तक का कहना है कि टाइप कन्स्ट्रक्टर का उपयोग केवल टाइप हस्ताक्षर में किया जाता है जबकि वास्तविक कंट्रोलर में वैल्यू कन्स्ट्रक्टर का उपयोग किया जाता है। यह यह दिखाने के लिए एक घोषणा का एक उदाहरण भी देता है कि दोनों के नाम एक-दूसरे से स्वतंत्र हैं। पहली जगह में दो रचनाकारों की आवश्यकता क्यों है, यदि उनमें से केवल एक वास्तविक कोड में उपयोग किया जाता है? चूंकि हम वास्तविक कोड में प्रकार के कन्स्ट्रक्टर का उपयोग नहीं करेंगे, टाइप कन्स्ट्रक्टर किस उद्देश्य का काम करता है?हास्केल में टाइप कन्स्ट्रक्टर के अलावा एक मूल्य कन्स्ट्रक्टर क्यों है?
उत्तर
शायद नाम थोड़ा भ्रामक हैं। टाइप कन्स्ट्रक्टर आपके द्वारा घोषित किए जा रहे प्रकार के नाम का प्रतिनिधित्व करता है। उन्हें इस तरह कहा जाता है क्योंकि वे प्रकार बनाते हैं, मान नहीं: वास्तव में, (संभवतः) प्रकार चर पर पैरामीटरकृत होते हैं, वे प्रकार के परिवार को परिभाषित करते हैं। वे सी ++ के टेम्पलेट्स और जावा के जेनेरिक जैसे कुछ कार्य करते हैं। data MyType a b = Constr a b
में, माईटाइप एक प्रकार का कन्स्ट्रक्टर है जो एक नया प्रकार (MyType a b)
बनाने के लिए दो प्रकार a
और b
लेता है।
ए वैल्यू कन्स्ट्रक्टर एकमात्र ऐसा हिस्सा है जिसे आप अन्य (ऑब्जेक्ट ओरिएंटेड) भाषाओं में "कन्स्ट्रक्टर" कहते हैं, क्योंकि आपको उस प्रकार के मान बनाने के लिए इसकी आवश्यकता होती है। तो, पिछले उदाहरण में, यदि आप मान कन्स्ट्रक्टर Constr :: a -> b -> MyType a b
लेते हैं, तो आप एक मान Constr "abc" 'd' :: MyType [Char] Char
बना सकते हैं। प्रकारों और मानों के बारे में अंतर्ज्ञान पाने के लिए
क्या मैं पूछ सकता हूं कि उस -1 से छुटकारा पाने के लिए मेरा जवाब कैसे सुधारें? क्या गलत है? –
एक सुविधाजनक तरीका है कि पूर्व संकलन समय मान रहे हैं जबकि बाद रन-टाइम मान हैं। दूसरे शब्दों में, कंस्ट्रक्चर समय पर अपने प्रोग्राम टाइप करने के एकमात्र उद्देश्य के लिए, हास्केल प्रकार के सेट में मानकों के निर्माता हैं। इसका मतलब यह भी है कि आप रन-टाइम पर एक प्रकार का निर्माण नहीं कर सकते हैं, और आप संकलन-समय पर एक मान नहीं बना सकते हैं।
इसलिए, क्योंकि आप एक प्रकार के मूल्य के आधार पर रन-टाइम पर स्पष्ट रूप से शाखा नहीं कर सकते हैं (हालांकि आप टाइपक्लास के साथ निस्संदेह कर सकते हैं), टाइप कन्स्ट्रक्टर रन-टाइम ऑब्जेक्ट्स के रूप में पूरी तरह बेकार हैं और कई मामलों में पूरी तरह से अनुपस्थित हैं अंतिम बाइनरी इसके विपरीत, क्योंकि मान निर्माता रचनात्मक समय पर अपने प्रकार के सेट में मूल्यों को बनाने की अनुमति देते हैं, वे संकलन-समय वस्तु के रूप में पूरी तरह बेकार हैं।
इस साधारण संपत्ति के कारण, टाइप कन्स्ट्रक्टर और वैल्यू कन्स्ट्रक्टर नामों को अनजाने में साझा कर सकते हैं।
यह अनिवार्य पृष्ठभूमि से आने वाले लोगों के लिए समझने का उत्तर सबसे आसान है! –
यह कहने की तरह थोड़ा सा है "हमें कक्षाएं और ऑब्जेक्ट्स की आवश्यकता क्यों है यदि वस्तुएं वास्तव में चलती हैं?"
दो प्रकार के निर्माता विभिन्न नौकरियां करते हैं। प्रकार रचनाकार टाइप प्रकार हस्ताक्षर में जाओ। मूल्य रचनाकार चलाने योग्य कोड में जाते हैं।
सबसे सरल मामले में, एक प्रकार "कन्स्ट्रक्टर" सिर्फ एक प्रकार का नाम है। सबसे सरल मामले में, एक प्रकार में केवल एक मान कन्स्ट्रक्टर होता है। तो तुम
data Point = Point Int Int
जैसी चीजों के साथ खत्म करने के लिए आप अपने आप को कहते हैं, "अब मैं क्यों बिल्ली Point
दो बार लिखने की ज़रूरत?"
data Tree x = Leaf x | Branch (Tree x) (Tree x)
यहाँ Tree
एक प्रकार निर्माता है:
लेकिन अब एक कम तुच्छ उदाहरण पर विचार करें।आप इसे एक प्रकार का तर्क देते हैं, और यह एक प्रकार का "निर्माण" करता है। तो Tree Int
एक प्रकार है, Tree String
एक और प्रकार है, और इसी तरह। (सी ++ में टेम्पलेट्स या जावा या एफिल में जेनेरिक की तरह।)
दूसरी ओर, Leaf
एक मूल्य निर्माता है। एक मूल्य को देखते हुए, यह 1-नोड का पेड़ बनाता है। तो Leaf 5
एक Tree Int
मान है, Leaf "banana"
एक Tree String
मान है, और इसी तरह।
इसी तरह Branch
के लिए। इसमें दो पेड़ के मूल्य होते हैं और बच्चों के रूप में उन पेड़ों के साथ पेड़ नोड बनाते हैं। उदाहरण के लिए, Branch (Leaf 2) (Leaf 7)
एक Tree Int
मान है।
विस्तृत स्पष्टीकरण के लिए धन्यवाद! –
- 1. कॉपी कन्स्ट्रक्टर सी ++ में डिफ़ॉल्ट कन्स्ट्रक्टर को क्यों छुपाता है?
- 2. मूल्य प्रकार के लिए डिफ़ॉल्ट कन्स्ट्रक्टर क्यों नहीं दिखता है?
- 3. ऑटोमैपर टाइप कनवर्टर कस्टम कन्स्ट्रक्टर
- 4. दायरे में नहीं: हास्केल में डेटा कन्स्ट्रक्टर
- 5. हास्केल डेटा कन्स्ट्रक्टर में इनपुट चेक
- 6. सी ++ में, केवल डिफॉल्ट कन्स्ट्रक्टर के साथ एक डिफॉल्ट कन्स्ट्रक्टर वाला कन्स्ट्रक्टर है?
- 7. कॉपी कन्स्ट्रक्टर और डिफॉल्ट कन्स्ट्रक्टर
- 8. कन्स्ट्रक्टर
- 9. एक कन्स्ट्रक्टर
- 10. कन्स्ट्रक्टर
- 11. कन्स्ट्रक्टर
- 12. जावा: एक कन्स्ट्रक्टर एक मूल्य कैसे वापस कर सकता है?
- 13. कन्स्ट्रक्टर में कॉल बेस कन्स्ट्रक्टर और अन्य कन्स्ट्रक्टर
- 14. कन्स्ट्रक्टर या कॉपी कन्स्ट्रक्टर?
- 15. कन्स्ट्रक्टर
- 16. कन्स्ट्रक्टर
- 17. टाइप प्रारंभकर्ता (स्थिर कन्स्ट्रक्टर) अपवाद हैंडलिंग
- 18. कन्स्ट्रक्टर
- 19. कन्स्ट्रक्टर
- 20. कन्स्ट्रक्टर
- 21. कन्स्ट्रक्टर
- 22. कन्स्ट्रक्टर
- 23. कन्स्ट्रक्टर
- 24. कन्स्ट्रक्टर
- 25. कन्स्ट्रक्टर
- 26. कन्स्ट्रक्टर
- 27. कन्स्ट्रक्टर
- 28. जावा: ऑब्जेक्ट क्लास में एक कन्स्ट्रक्टर है?
- 29. प्रोटोटाइप के कन्स्ट्रक्टर को अपने कन्स्ट्रक्टर फ़ंक्शन में क्यों सेट किया गया है?
- 30. जावा में एक कॉपी कन्स्ट्रक्टर क्यों नहीं है?
वाक्यांश "वास्तविक कोड" दुर्भाग्यपूर्ण है, क्योंकि इसका तात्पर्य है कि आप प्रोग्राम्स में प्रकार के कन्स्ट्रक्टर का उपयोग नहीं करेंगे, जब लेखकों का वास्तव में मतलब है कि टाइपर कन्स्ट्रक्टर केवल टाइप एनोटेशन के लिए उपयोग किए जाते हैं। यह कहने के बराबर है कि आपको सी में "int" या "long" कीवर्ड की आवश्यकता नहीं है क्योंकि आप उन्हें वास्तविक कोड में उपयोग नहीं करते हैं (वे केवल घोषणाओं में उपयोग किए जाते हैं, जो "वास्तविक कोड" के रूप में नहीं गिने जाते हैं "इस मानक से)। –
... कोई स्वीकार नहीं करता है? :) –