यह क्यों संकलित नहीं है? :
<पूर्व> आयात करें java.util.Optional; सार्वजनिक वर्ग के डेमो {वैकल्पिक> यह बिना किसी समस्या के काम करता है जब getOption ()
एक वैकल्पिक वापस करेगा।
यह एक सीमित प्रतिबंधित विधि हस्ताक्षर का परिणाम है:
सार्वजनिक T orElseGet (आपूर्तिकर्ता & lt ;? T & gt; अन्य का विस्तार करता है) { आपके मामले में, T
है ? कुछ वैल्यू
फैलता है जो एक अज्ञात प्रकार है जो SomeValue
के लिए असाइन किया जा रहा है (लेकिन यह एक उपवर्ग हो सकता है)। orElseGet
के हस्ताक्षर का अर्थ है कि आपके सप्लायर को T
के उपप्रकार वापस करने की अनुमति है, जिसके परिणामस्वरूप T
के समग्र परिणाम का प्रकार होता है लेकिन यह अनुमति नहीं देता है एक सामान्य आधार प्रकार T
को चौड़ा करने के लिए और आपके आपूर्तिकर्ता के प्रकार (यदि आपका सप्लायर रिटर्न SomeValue
और T
है कुछ वैल्यू
बढ़ाता है, सामान्य आधार प्रकार कुछ वैल्यू
होगा।)
आप एक ऑपरेशन डालकर इसे ठीक कर सकते हैं जो इस प्रकार की चौड़ाई को अनुमति देता है:
कुछ वैल्यू कुछ वैल्यू = getOption () .मैप (फ़ंक्शन। & Lt; SomeValue & gt; पहचान ()) orElseGet (() - & gt; नया कुछ वैल्यू ());
पहचान
फ़ंक्शन वैल्यू बदल नहीं करता है, लेकिन मैपिंग ऑपरेशन एक व्यापक प्रकार का उपयोग करने वाला फ़ंक्शन पास करने की अनुमति देता है, अर्थात मैपिंग फ़ंक्शन उपभोग करने की घोषणा कर सकता है कुछ वैल्यू
जब वास्तविक इनपुट प्रकार है? कुछ वैल्यू
बढ़ाता है और वापसी का प्रकार कुछ वैल्यू है।
लेकिन आम तौर पर, इस तरह की समस्याओं से बचने के लिए, तरीकों को उनके रिटर्न प्रकारों में वाइल्डकार्ड नहीं होना चाहिए, इसलिए परिवर्तन <पूर्व> वैकल्पिक & lt ;? कुछ वैल्यू & gt; फैलता है GetOption ()
से
वैकल्पिक & lt; SomeValue & gt; एक वाइल्डकार्ड का उपयोग एक वापसी के प्रकार से किया जाना चाहिए क्योंकि यह प्रोग्रामर को वाइल्डकार्ड से निपटने के लिए कोड का उपयोग करने के लिए बाध्य करता है। >
No comments:
Post a Comment