मैंने इन्हें सी और सी ++ के संदर्भ में देखा है, लेकिन हस्ताक्षरित और हस्ताक्षरित चर के बीच क्या अंतर है?हस्ताक्षरित और हस्ताक्षरित चर के बीच क्या अंतर है?
उत्तर
हस्ताक्षर चर, जैसे हस्ताक्षर किए पूर्णांक आप सकारात्मक और नकारात्मक दोनों पर्वतमाला में संख्याओं का प्रतिनिधित्व करने की अनुमति देगा। ऐसे अहस्ताक्षरित पूर्णांक के रूप में
अहस्ताक्षरित चर,, केवल आप सकारात्मक में संख्याओं का प्रतिनिधित्व करने की अनुमति देगा। एक ही प्रकार के
अहस्ताक्षरित और हस्ताक्षर किए चर (जैसे int
और byte
के रूप में) दोनों एक ही रेंज (65,536 और 256 नंबर की सीमा, क्रमशः) है, लेकिन अहस्ताक्षरित चर पर हस्ताक्षर किए वाली संबंधित तुलना में एक बड़ा परिमाण संख्या का प्रतिनिधित्व कर सकते ।
उदाहरण के लिए, एक unsigned byte
मूल्यों 0
से 255
करने के लिए, का प्रतिनिधित्व करते हुए signed byte
127
को -128
प्रतिनिधित्व कर सकते हैं कर सकते हैं।
Signed number representations पर विकिपीडिया पृष्ठ बिट स्तर पर प्रतिनिधित्व में अंतर बताता है, और Integer (computer science) पृष्ठ प्रत्येक हस्ताक्षरित/हस्ताक्षरित पूर्णांक प्रकार के लिए श्रेणियों की एक तालिका प्रदान करता है।
सकारात्मक संख्या शून्य से अधिक है। हस्ताक्षर संख्या, कम से कम सी में, एक पूरक प्रतिनिधित्व के बजाय एक साइन बिट का उपयोग कर सकते हैं, इसलिए दोहराए गए +/- शून्य के कारण हस्ताक्षरित के समान सीमा नहीं है। यदि आप कहते हैं कि int int 16 बिट है, तो प्लेटफ़ॉर्म कहें; अधिकांश आधुनिक सिस्टम 32 या 64 बिट हैं। –
साइन किए गए वेरिएबल ध्वजांकित करने के लिए एक बिट का उपयोग करते हैं चाहे वे सकारात्मक या नकारात्मक हों। असाइन किए गए चर के पास यह बिट नहीं है, इसलिए वे एक ही स्थान पर बड़ी संख्या में स्टोर कर सकते हैं, लेकिन केवल nonnegative संख्याएं, उदा। 0 और उच्चतम।
अधिक जानकारी के लिए: Unsigned and Signed Integers
बिना हस्ताक्षर किए गए चर केवल सकारात्मक संख्या हो सकते हैं, क्योंकि उनमें यह इंगित करने की क्षमता नहीं है कि वे नकारात्मक हैं।
इस क्षमता को 'साइन' या 'साइनिंग बिट' कहा जाता है।
एक दुष्प्रभाव यह है कि बिना हस्ताक्षर किए बिट के, उनके पास एक और बिट है जिसका उपयोग संख्या का प्रतिनिधित्व करने के लिए किया जा सकता है, जो अधिकतम संख्या को प्रदर्शित कर सकता है।
हस्ताक्षर चर 0, सकारात्मक या नकारात्मक हो सकता है।
बिना हस्ताक्षर किए गए चर 0 या सकारात्मक हो सकते हैं।
असाइन किए गए चर का उपयोग कभी-कभी किया जाता है क्योंकि वास्तविक बिट का प्रतिनिधित्व करने के लिए अधिक बिट्स का उपयोग किया जा सकता है। आपको एक बड़ी रेंज दे रही है। साथ ही आप यह सुनिश्चित कर सकते हैं कि उदाहरण के लिए आपके फ़ंक्शन पर नकारात्मक मान नहीं दिया जाएगा।
अहस्ताक्षरित चर चर जो आंतरिक रूप से एक गणितीय चिह्न (प्लस या माइनस) 'शून्य' स्टोर कर सकते हैं या सकारात्मक मूल्यों केवल बिना प्रतिनिधित्व कर रहे हैं कर रहे हैं। आइए मान लें कि हस्ताक्षरित चर एन बिट्स आकार में है, तो यह 2^एन (2 पावर एन) मानों - 0 (2^एन -1) का प्रतिनिधित्व कर सकता है। दूसरी तरफ एक हस्ताक्षरित चर, संकेत का प्रतिनिधित्व करने के लिए 'एक' खो देता है, इसलिए यह शून्य सहित (2^(एन -1) -1) (2^(एन -1)) के मूल्यों को स्टोर कर सकता है।इस प्रकार, हस्ताक्षरित चरसकारात्मक मान, नकारात्मक मान और शून्य स्टोर कर सकता है।
पुनश्च:
आंतरिक रूप से, गणितीय संकेत, किसी के पूरक के रूप में प्रस्तुत किया जा सकता दो के पूरक फार्म या एक संकेत बिट के साथ (जैसे: 0 -> +, 1-> -)
सभी इन तरीकों को प्रभावी ढंग से एन बिट्स (2^एन) में तीन भागों, सकारात्मक, नकारात्मक और शून्य में प्रतिनिधित्व योग्य मानों की सीमा को विभाजित करें।
यह सिर्फ मेरे दो सेंट मूल्य है।
मुझे उम्मीद है कि इससे मदद मिलती है।
अहस्ताक्षरित प्रयोग किया जाता है जब उर मूल्य सकारात्मक होना चाहिए, कोई नकारात्मक मूल्य यहाँ, अगर यदि अहस्ताक्षरित int श्रृंखला के लिए 32,767 को पूर्णांक रेंज -32,768 के लिए हस्ताक्षर किए 0 65535
को आमतौर पर करने के लिए एक के रूप में संदर्भित करते हुए ' साइन बिट ', आमतौर पर उपयोग किए जाने वाले द्विआधारी मूल्यों में सही साइन बिट नहीं होता है।
अधिकांश कंप्यूटर दो के पूरक अंकगणित का उपयोग करते हैं।ऋणात्मक संख्याओं को one's-पूरक (सभी बिट्स फ्लिप) ले रहे हैं और एक जोड़कर बनाया जाता है:
5 (decimal) -> 00000101 (binary)
1's complement: 11111010
add 1: 11111011 which is 'FB' in hex
यही कारण है कि एक हस्ताक्षरित बाइट -128 से 127 के बजाय -127 को 127 करने के लिए मान रखती है:
1 0 0 0 0 0 0 0 = -128
1 0 0 0 0 0 0 1 = -127
- - -
1 1 1 1 1 1 1 0 = -2
1 1 1 1 1 1 1 1 = -1
0 0 0 0 0 0 0 0 = 0
0 0 0 0 0 0 0 1 = 1
0 0 0 0 0 0 1 0 = 2
- - -
0 1 1 1 1 1 1 0 = 126
0 1 1 1 1 1 1 1 = 127
(जोड़ने 127 करने के लिए 1 देता है :)
1 0 0 0 0 0 0 0
जो हम इस चार्ट के शीर्ष पर देखना -128 है।
यदि हमारे पास उचित साइन बिट था, तो मूल्य सीमा समान होगी (उदा। -127 से +127) क्योंकि एक बिट साइन के लिए आरक्षित है। सबसे महत्वपूर्ण बिट संकेत सा है, तो हम चाहते हैं:
5 (decimal) -> 00000101 (binary)
-5 (decimal) -> 10000101 (binary)
इस मामले में दिलचस्प बात यह है हमारे पास है शून्य और ऋणात्मक शून्य दोनों:
0 (decimal) -> 00000000 (binary)
-0 (decimal) -> 10000000 (binary)
हम की जरूरत नहीं है -0 two's-पूरक के साथ; क्या होगा -08 -128 (या अधिक सामान्य होने के लिए, सबसे बड़ा सकारात्मक मूल्य से अधिक)। हम हालांकि किसी के पूरक के साथ करते हैं; सभी 1 बिट नकारात्मक हैं 0.
गणितीय, -0 बराबर 0. मुझे अस्पष्ट रूप से एक कंप्यूटर याद है जहां -0 < 0, लेकिन मुझे अब इसका कोई संदर्भ नहीं मिल रहा है।
बहुत बहुत धन्यवाद! मैं वास्तव में उलझन में था कि यह हस्ताक्षर किए गए बाइट के लिए -128 से 127 क्यों है और 127 से 127 तक नहीं। इस उत्तर को वोटों की आवश्यकता है! –
यह सटीक परिभाषा नहीं हो सकती है लेकिन मैं आपको एक उदाहरण दूंगा: यदि आप सिस्टम समय से इसे यादृच्छिक संख्या बनाना चाहते हैं, तो यहां हस्ताक्षर किए गए चर का उपयोग करना फायदेमंद है क्योंकि यादृच्छिक रूप से बड़े दायरे हैं हस्ताक्षरित संख्याओं के रूप में संख्या सकारात्मक और नकारात्मक दोनों संख्या देते हैं। चूंकि सिस्टम समय नकारात्मक नहीं हो सकता है, इसलिए हम हस्ताक्षरित चर (केवल सकारात्मक संख्या) का उपयोग करते हैं और हमारे पास यादृच्छिक संख्याओं की विस्तृत श्रृंखला है।
- 1. MySQL में हस्ताक्षरित और हस्ताक्षरित के बीच का अंतर?
- 2. हस्ताक्षरित और हस्ताक्षरित .apk फ़ाइलों के बीच एंड्रॉइड अंतर?
- 3. स्व-हस्ताक्षरित सीए और स्वयं हस्ताक्षरित प्रमाणपत्र
- 4. एक हस्ताक्षरित और हस्ताक्षरित 32-बिट पूर्णांक चर
- 5. क्या VHDL numeric_std हस्ताक्षरित/हस्ताक्षरित
- 6. क्या कोई इंटरेन्स हस्ताक्षरित या हस्ताक्षरित है?
- 7. int और हस्ताक्षरित int घोषणा के बीच अंतर
- 8. कंप्यूटर पूर्णांक में अंतर कैसे हस्ताक्षरित या हस्ताक्षरित है?
- 9. हस्ताक्षरित और हस्ताक्षरित मानों का क्या अर्थ है?
- 10. बिटवाईट शिफ्ट ऑपरेटर। हस्ताक्षरित और हस्ताक्षरित
- 11. हस्ताक्षरित डेटाटाइप क्या है?
- 12. कक्षा 1 और कक्षा 3 जड़ों और उनके द्वारा हस्ताक्षरित प्रमाणपत्रों के बीच क्या अंतर है?
- 13. हस्ताक्षरित वर्णों को हस्ताक्षरित पूर्णांक
- 14. ptrdiff_t के हस्ताक्षरित समकक्ष क्या है?
- 15. Uint32 और C++ में एक हस्ताक्षरित int के बीच क्या अंतर है?
- 16. हस्ताक्षर/हस्ताक्षरित
- 17. बाइट्स का बफर हस्ताक्षरित या हस्ताक्षरित चार बफर होना चाहिए?
- 18. मैं चेतावनियों को कैसे ठीक कर सकता हूं: "हस्ताक्षरित और हस्ताक्षरित के बीच तुलना"?
- 19. x86 (-64) पर हस्ताक्षरित और हस्ताक्षरित गुणात्मक निर्देश क्यों हैं?
- 20. जीसीसी एक हस्ताक्षरित var और एक हस्ताक्षरित शाब्दिक
- 21. सदस्य चर और स्थानीय चर के बीच क्या अंतर है?
- 22. हस्ताक्षरित जार
- 23. हस्ताक्षरित संख्या
- 24. आकार_टी हमेशा हस्ताक्षरित है?
- 25. हस्ताक्षरित प्रमाणपत्र
- 26. सी/सी ++ में हस्ताक्षरित लंबे/लंबे/int के बीच क्या अंतर है?
- 27. सी - हस्ताक्षरित int सरणी रूपांतरण के लिए हस्ताक्षरित int
- 28. एक हस्ताक्षरित चार
- 29. PHP में हस्ताक्षरित tinyint?
- 30. चार हस्ताक्षरित पूर्णांक (सी ++)
मैंने सोचा कि हम डिफ़ॉल्ट रूप से प्रोग्रामिंग में मानते हैं और जब प्रोग्रामिंग से संबंधित नहीं है? –
मैंने ऐसा किया। मुझे प्रोग्रामिंग के तहत कुछ कतारें मिलीं। मुझे आश्चर्य है क्योंकि? – batbrat
प्रश्न सामान्य रूप से प्रोग्रामिंग के एक विशिष्ट पहलू से संबंधित है। – Sam152