कार्यात्मक प्रोग्रामिंग - आलसी मूल्यांकन

आलसी मूल्यांकन एक मूल्यांकन रणनीति है जो किसी अभिव्यक्ति का मूल्यांकन तब तक रखती है जब तक उसके मूल्य की आवश्यकता नहीं होती है। यह बार-बार मूल्यांकन से बचा जाता है।Haskell इस तरह की एक कार्यात्मक प्रोग्रामिंग भाषा का एक अच्छा उदाहरण है, जिसकी बुनियादी बातें आलसी मूल्यांकन पर आधारित हैं।

आलसी मूल्यांकन का उपयोग यूनिक्स मानचित्र कार्यों में डिस्क से केवल आवश्यक पृष्ठों को लोड करके उनके प्रदर्शन को बेहतर बनाने के लिए किया जाता है। शेष पृष्ठों के लिए कोई मेमोरी आवंटित नहीं की जाएगी।

आलसी मूल्यांकन - लाभ

  • यह भाषा रनटाइम को उप-अभिव्यक्तियों को छोड़ने की अनुमति देता है जो सीधे अभिव्यक्ति के अंतिम परिणाम से जुड़े नहीं हैं।

  • यह अस्थायी संगणना और सशर्त को त्यागकर एक एल्गोरिथ्म की समय जटिलता को कम करता है।

  • यह प्रोग्रामर को डेटा संरचनाओं के घटकों का उपयोग करने की अनुमति देता है, जो उन्हें किसी भी परिपत्र निर्भरता से मुक्त करने के बाद उन्हें शुरू करने के आदेश देता है।

  • यह डेटा लोड करने के लिए सबसे उपयुक्त है जिसे बार-बार एक्सेस किया जाएगा।

आलसी मूल्यांकन - कमियां

  • यह भाषा रनटाइम को उप-अभिव्यक्तियों के मूल्यांकन के लिए बाध्य करता है जब तक कि इसे अंतिम परिणाम बनाने की आवश्यकता न हो thunks (विलंबित वस्तुएं)।

  • कभी-कभी यह एक एल्गोरिथ्म के अंतरिक्ष जटिलता को बढ़ाता है।

  • इसके प्रदर्शन को खोजना बहुत मुश्किल है क्योंकि इसमें उनके निष्पादन से पहले भावों के थ्रक्स शामिल हैं।

पायथन का उपयोग करके आलसी मूल्यांकन

rangeपाइथन में विधि आलसी मूल्यांकन की अवधारणा का अनुसरण करती है। यह बड़ी श्रेणियों के लिए निष्पादन का समय बचाता है और हमें कभी भी सभी मूल्यों की आवश्यकता नहीं होती है, इसलिए यह मेमोरी की खपत को भी बचाता है। निम्नलिखित उदाहरण पर एक नज़र डालें।

r = range(10) 
print(r) 
range(0, 10) 
print(r[3])

यह निम्नलिखित उत्पादन का उत्पादन करेगा -

[0, 1, 2, 3, 4, 5, 6, 7, 8, 9] 
3