पायथन में हमारे पास एक सॉफ्ट कीवर्ड की अवधारणा है, जो कुछ कीवर्ड को केवल कुछ विशेष मामलों (जैसे मैच, केस और प्रकार) में आरक्षित बनाता है।
मैंने जो व्याख्या की है, उसके अनुसार आमतौर पर भाषा डिजाइनर किसी भाषा में आरक्षित शब्दों की संख्या को कम करने का प्रयास करते हैं। तो जब हम एक कीवर्ड को सॉफ्ट कीवर्ड के रूप में रख सकते हैं, तो सभी कीवर्ड के लिए इसका उपयोग क्यों न करें? सभी आरक्षित शब्दों के लिए सॉफ्ट कीवर्ड का उपयोग करने में क्या समस्या है?
मैं इसे और अधिक संक्षिप्त बनाने के लिए अपने प्रश्न को दोबारा बदलना चाहता हूं:
भाषा डिजाइनर सॉफ्ट कीवर्ड का अधिकतम उपयोग करने का प्रयास क्यों नहीं करते? पायथन में कई हार्ड कीवर्ड हैं जो सॉफ्ट कीवर्ड हो सकते हैं (जैसे डीईएफ़, क्लास, इंपोर्ट, आदि)। यदि भाषा डिजाइनर चाहते हैं कि उनकी भाषा में कम से कम आरक्षित शब्द हों (यदि यह धारणा गलत है तो कृपया मुझे सुधारें) तो वे इन कठिन कीवर्ड को सॉफ्ट में क्यों नहीं बदल देते?
पायथन में सॉफ्ट कीवर्ड
यदि भाषा डिजाइनर चाहते हैं कि उनकी भाषा में कम से कम आरक्षित शब्द हों (यदि यह धारणा गलत है तो कृपया मुझे सुधारें) तो वे इन कठिन कीवर्ड को सॉफ्ट में क्यों नहीं बदल देते?
यह धारणा गलत है। मैं विज़ुअल बेसिक, वीबीस्क्रिप्ट, जावास्क्रिप्ट, सी# और अन्य के लिए डिज़ाइन समितियों में रहा हूं, और उनमें से किसी भी डिज़ाइन समिति में हमने कभी डिज़ाइन लक्ष्य के रूप में "आरक्षित शब्दों की संख्या को कम करने" पर भी विचार किया था। हेक, नेटस्केप ने जावा के सभी कीवर्ड जावास्क्रिप्ट में आरक्षित कर दिए हैं - याद रखें, जावास्क्रिप्ट को विपणन कारणों से बुलाया गया था, इसलिए नहीं कि इसका जावा से कोई लेना-देना है - सिर्फ इसलिए कि किसी दिन वे जावास्क्रिप्ट में कोई भी जावा सुविधा चाहते होंगे।
भाषा डिज़ाइनर सॉफ्ट कीवर्ड का अधिकतम उपयोग करने का प्रयास क्यों नहीं करते?
क्योंकि यह सीधे तौर पर आधुनिक सामान्य प्रयोजन लाइन-ऑफ-बिजनेस भाषाओं के डिजाइनरों के प्राथमिक लक्ष्य के विरुद्ध काम करेगा! "सॉफ्ट कीवर्ड को अधिकतम करें" अधिक सामान्य सिद्धांत का एक विशेष मामला है "उपयोगकर्ता की अभिव्यंजक पसंद को अधिकतम करने के लिए यथासंभव कानूनी कार्यक्रमों के रूप में कई स्ट्रिंग बनाएं", और यह एक डिज़ाइन सिद्धांत नहीं है कि आधुनिक एलओबी भाषाएं इसकी बहुत परवाह करती हैं