इसके बाद, हम N4140 (C ++ 14 स्टैंडर्ड) का उपयोग करते हैं।
के अनुसार 17.6.3.4 हैश आवश्यकताओं § ,
लौटाया गया मान केवल
k
कार्यक्रम की अवधि के लिए तर्क पर निर्भर करेगा ।[नोट: इस प्रकार कार्यक्रम के दिए गए निष्पादन के लिए समान परिणाम प्राप्त करने के लिए एक
h(k)
ही मूल्य के साथ अभिव्यक्ति के सभी मूल्यांकन । - अंतिम नोट]k
और § 20.9.12 क्लास टेम्पलेट हैश कहता है
...
तात्कालिकता
hash<Key>
होगी:(१.१) - हैश आवश्यकताओं को संतुष्ट करें (१ ).६.३.४) ...
(१.२) - ...
इसका मतलब है कि हैश मान value
(यानी hash<decltype(value)>(value)
) यदि आप प्रोग्राम को पुनरारंभ करते हैं तो एक अलग मान ले सकते हैं।
लेकिन क्यों? यह सीमा C ++ 11 के मानक में नहीं थी, लेकिन C ++ 14, C ++ 17 और C ++ 20 के मानक में थी। एक उपयोगकर्ता (एसटीएल डेवलपर नहीं) के रूप में, यह काफी उपयोगी होगा यदि std::hash
यह निर्धारक हो। क्या नियतात्मक हैश फ़ंक्शन को लागू करने में कोई गणितीय कठिनाइयाँ हैं? लेकिन हैश फ़ंक्शन हम दैनिक उपयोग करते हैं (जैसे पदावनत md5sum
या सुरक्षित sha256
) सभी नियतात्मक हैं। क्या दक्षता की समस्या है?