सी ++ में हम प्राइमेटिव unsigned
बना सकते हैं। लेकिन वे हमेशा सकारात्मक होते हैं। क्या हस्ताक्षर किए गए नकारात्मक चर बनाने का कोई तरीका है? मुझे बिना हस्ताक्षर किए गए शब्द "हस्ताक्षर किए गए शब्द" पता है, इसलिए एक ऋण (-) चिह्न भी नहीं है। लेकिन मुझे लगता है कि सी ++ इसे प्रदान करना होगा।असीमित नकारात्मक प्राइमेटिव्स?
उत्तर
सं। unsigned
में केवल गैर-संख्यात्मक संख्याएं हो सकती हैं।
यदि आपको एक ऐसे प्रकार की आवश्यकता है जो केवल ऋणात्मक संख्याओं का प्रतिनिधित्व करे, तो आपको स्वयं को एक कक्षा लिखनी होगी, या केवल अपने प्रोग्राम में मूल्य को नकारात्मक समझना होगा।
(लेकिन आप इस तरह के एक प्रकार की जरूरत क्यों करते हैं?)
तो, अगर मैं वास्तव में यह चाहता हूं, तो मुझे अपनी खुद की कक्षा बनाने और नकारात्मक ऑपरेटर अनुकरण करने के लिए कुछ ऑपरेटर ओवरलोडिंग करने की आवश्यकता होगी? –
@ केनीटीएम: अगर मैं जितनी कम संभव स्मृति का उपयोग करना चाहता हूं। –
@ मार्टिजन: यह समयपूर्व अनुकूलन की तरह लगता है। आपको कितने नंबर चाहिए? उन संख्याओं की सीमा क्या है? – kennytm
unsigned
पूर्णांक केवल सकारात्मक रहे हैं। 2003 C++ मानक के 3.9.1 पैरा 3 से:
एक पर हस्ताक्षर किए पूर्णांक प्रकार के गैर नकारात्मक मानों की श्रेणी के subrange इसी अहस्ताक्षरित पूर्णांक प्रकार, और प्रत्येक की कीमत प्रतिनिधित्व वाली संबंधित हस्ताक्षर किए है/हस्ताक्षरित प्रकार समान होगा।
हस्ताक्षरित पूर्णांक प्रकारों का मुख्य उद्देश्य मॉड्यूलो अंकगणितीय का समर्थन करना है। 3.9.1 अनुच्छेद 4 से:
अहस्ताक्षरित पूर्णांकों, अहस्ताक्षरित घोषित, अंकगणित सापेक्ष के नियमों का पालन करेगा 2 n जहां n कि विशेष रूप से आकार का मूल्य प्रतिनिधित्व में बिट्स के संख्या है पूर्णांक का।
यदि आप चाहें तो नकारात्मक रूप से उनका इलाज करने के लिए आप नि: शुल्क हैं, आपको बस किसी भी तरह (शायद एक बूलियन ध्वज के साथ) का ट्रैक रखना होगा।
मुझे लगता है कि आप इसे गलत तरीके से सोच रहे हैं।
आप एक ऋणात्मक संख्या चाहते हैं, तो आप चर अहस्ताक्षरित के रूप में घोषित नहीं करना चाहिए।
आपकी समस्या को मूल्य सीमा है, और आपको लगता है कि एक और बिट, तो आप एक "बड़ा" डेटा प्रकार इस्तेमाल कर सकते हैं चाहते हैं (उदाहरण के लिए 64 int ...)।
तो फिर तुम विरासत कोड का उपयोग करता है, तो कर रहे हैं, एक नया struct आपकी समस्या का समाधान कर सकते हैं बनाने, लेकिन यह अपने विशिष्ट स्थिति की वजह से इस तरह से है, सी ++ इसे संभाल नहीं करना चाहिए।
नाम से मूर्ख मत बनो: हस्ताक्षर किए जाने वाले अक्सर गैर-नकारात्मक के रूप में गलत समझा जाता है, लेकिन भाषा के नियम अलग-अलग होते हैं ... शायद एक बेहतर नाम "बिटमैस्क" या "मॉड्यूलो_इन्टेगर" होता।
यदि आपको लगता है कि हस्ताक्षरित गैर-ऋणात्मक है तो उदाहरण के लिए निहित रूपांतरण नियम कुल बकवास हैं (क्यों दो गैर-नकारात्मक के बीच अंतर गैर-नकारात्मक होना चाहिए? गैर-नकारात्मक और पूर्णांक के अतिरिक्त क्यों होना चाहिए गैर नकारात्मक हो?)।
यह बहुत दुर्भाग्यपूर्ण है कि सी ++ मानक लाइब्रेरी स्वयं उस गलतफहमी में गिर गई क्योंकि उदाहरण के लिए vector.size() को हस्ताक्षर नहीं किया गया है (बेतुका अगर आप इसका अर्थ यह है कि भाषा स्वयं बिटमैस्क या मॉड्यूलो_इन्टेगर के मामले में होती है)।आकारों के लिए इस विकल्प को पुराने 16-बिट बार बिना हस्ताक्षर किए गए नास के साथ करना है और यह मेरी राय में एक भयानक पसंद है जिसे हम अभी भी बग के रूप में भुगतान कर रहे हैं।
vector.size() पर हस्ताक्षर करने से क्या लाभ मिलता है? यह कभी ऋणात्मक मूल्य वापस नहीं कर सकता है। हस्ताक्षरित/हस्ताक्षरित होने के कारण वास्तव में कौन सी बग उत्पन्न होती है? यह सौदा करने के लिए एक बहुत ही सरल अवधारणा है। – Puppy
मैंने देखा सबसे आम बग 0 से vector.size() - 1 है कि एक खाली वेक्टर के लिए एक बड़ी संख्या है। अन्य संभावित बग इस तथ्य से उत्पन्न होते हैं कि ए - बी> 0 ए> बी के समान नहीं है। ध्यान दें कि यह सब इसलिए होता है क्योंकि सी ++ के लिए हस्ताक्षरित का अर्थ है ज़ेड [एन] "(ज़ेड [एन] = पूर्णांक मॉड्यूलो एन) का तत्व कम या कम है और इसमें साइन के साथ कुछ लेना देना नहीं है। आपकी राय में यह समझ में आता है कि वेक्टर में तत्वों की संख्या उस अंगूठी का एक तत्व है? बिना हस्ताक्षर किए गए इंट्स आईएमओ वास्तव में बहुत उपयोगी हैं ... लेकिन मात्रा के रूप में नहीं। – 6502
ठीक है, तो आपको एक अप्रत्याशित मान मिलता है। अंडरफ्लो प्राप्त करने से बेहतर कैसे है? कम से कम इस तरह आप अपनी याददाश्त को उलझन में नहीं डाल रहे हैं। –
लेकिन मुझे लगता है कि सी ++ इसे प्रदान करना होगा।
क्यों? आपको लगता है कि सी ++ को गैर-नकारात्मक संख्या नकारात्मक बनाने की क्षमता प्रदान करनी चाहिए? यह मूर्खतापूर्ण है।
सी ++ में असाइन किए गए मान हमेशा गैर-नकारात्मक होने के लिए परिभाषित किए जाते हैं। वे शून्य पर — को बहने के बजाय — को भी लपेटते हैं! (और सीमा के दूसरे छोर पर)
- 1. जावा मैपिंग्स और प्राइमेटिव्स
- 2. बॉक्सिंग प्राइमेटिव्स और समतुल्यता
- 3. प्राइमेटिव्स का ऑटो बॉक्सिंग
- 4. प्राइमेटिव्स और एरे/प्राइमेटिव्स के संग्रह को संभालने के लिए जीयूआई लाइब्रेरी
- 5. गुणा के बाद नकारात्मक मान नकारात्मक- जावा
- 6. असीमित आईओ?
- 7. असीमित UIScrollView
- 8. असीमित memcpy?
- 9. नकारात्मक संख्या
- 10. नकारात्मक प्रत्यय
- 11. MySQL ऑफ़सेट असीमित पंक्तियां
- 12. कॉलबैक हमेशा असीमित हैं?
- 13. असीमित संग्रहीत प्रक्रिया
- 14. तुल्यकालिक बनाम असीमित भाषाओं
- 15. PHP MySQLi असीमित क्वेरीज
- 16. असीमित मल्टीथ्रेडिंग अपवाद हैंडलिंग?
- 17. वेल्ड - असीमित घटना पर्यवेक्षक
- 18. बेवकूफ: असीमित रेंज
- 19. SqlDataAdapter.Fill - असीमित दृष्टिकोण
- 20. असीमित स्क्रॉल और कॉलबैक
- 21. असीमित वाक्यविन्यास: अप्रत्याशित पहचानकर्ता?
- 22. एक्सटेंशन विधि बनाना असीमित
- 23. बैंड असीमित तरंग उत्पादन
- 24. असीमित के लिए लूप
- 25. एमएस-एक्सेल नकारात्मक समय
- 26. सबसे नकारात्मक मूल्य अजगर
- 27. गैर नकारात्मक पूर्णांक
- 28. नकारात्मक वजन चक्र एल्गोरिदम
- 29. यादृच्छिक और नकारात्मक संख्या
- 30. नियमित अभिव्यक्ति नकारात्मक मिलान
सी/सी ++ में "हस्ताक्षरित" वास्तव में nonnegative के लिए समानार्थी है। –
बस मान लें कि वे नकारात्मक संख्याओं का प्रतिनिधित्व करते हैं। – AraK
दिलचस्प सवाल मैंने पहले कभी नहीं सुना है। दुर्भाग्य से, जवाब नहीं है।" –