好吧,我被征服了—— 關(guān)于 c++ unsigned char
2 i=-20;
3
今天群里的新學(xué)c++同學(xué)問(wèn)我,unsighed char 和char 有啥區(qū)別,上面的輸出會(huì)有什么 不同
在這里,我先鄙視一下自己,我直觀的理解為通常的 首位符號(hào)位,然后丟下的就是輸入無(wú)符號(hào)的。好吧,估計(jì)各位看官說(shuō)我太菜,但確實(shí)是輸出的結(jié)果和我想的不大一樣,如果各位沒(méi)明白我說(shuō)的是什么問(wèn)題,可以試一下。然后回來(lái)看下面的內(nèi)容。
。
In an unsigned type, all the bits represent the value. If a type is defined for a particular machine to use 8 bits, then the unsigned version of this type could hold the values 0 through 255.
無(wú)符號(hào)型中,所有的位都表示數(shù)值。如果在某種機(jī)器中,定義一種類(lèi)型使用 8 位表示,那么這種類(lèi)型的 unsigned 型可以取值 0 到 255。
The C++ standard does not define how signed types are represented at the bit level. Instead, each compiler is free to decide how it will represent signed types. These representations can affect the range of values that a signed type can hold. We are guaranteed that an 8-bit signed type will hold at least the values from 127 through 127; many implementations allow values from 128 through 127.
C++ 標(biāo)準(zhǔn)并未定義 signed 類(lèi)型如何用位來(lái)表示,而是由每個(gè)編譯器自由決定如何表示 signed 類(lèi)型。這些表示方式會(huì)影響 signed 類(lèi)型的取值范圍。8 位 signed 類(lèi)型的取值肯定至少是從 -127 到 127,但也有許多實(shí)現(xiàn)允許取值從 -128 到 127。
Under the most common strategy for representing signed integral types, we can view one of the bits as a sign bit. Whenever the sign bit is 1, the value is negative; when it is 0, the value is either 0 or a positive number. An 8-bit integral signed type represented using a sign-bit can hold values from 128 through 127.
表示 signed 整型類(lèi)型最常見(jiàn)的策略是用其中一個(gè)位作為符號(hào)位。符號(hào)位為 1,值就為負(fù)數(shù);符號(hào)位為 0,值就為 0 或正數(shù)。一個(gè) signed 整型取值是從 -128 到 127。
Assignment to Integral Types
整型的賦值
The type of an object determines the values that the object can hold. This fact raises the question of what happens when one tries to assign a value outside the allowable range to an object of a given type. The answer depends on whether the type is signed or unsigned.
對(duì)象的類(lèi)型決定對(duì)象的取值。這會(huì)引起一個(gè)疑問(wèn):當(dāng)我們?cè)囍岩粋€(gè)超出其取值范圍的值賦給一個(gè)指定類(lèi)型的對(duì)象時(shí),結(jié)果會(huì)怎樣呢?答案取決于這種類(lèi)型是 signed 還是 unsigned 的。
For unsigned types, the compiler must adjust the out-of-range value so that it will fit. The compiler does so by taking the remainder of the value modulo the number of distinct values the unsigned target type can hold. An object that is an 8-bit unsigned char, for example, can hold values from 0 through 255 inclusive. If we assign a value outside this range, the compiler actually assigns the remainder of the value modulo 256. For example, we might attempt to assign the value 336 to an 8-bit signed char. If we try to store 336 in our 8-bit unsigned char, the actual value assigned will be 80, because 80 is equal to 336 modulo 256.
對(duì)于 unsigned 類(lèi)型來(lái)說(shuō),編譯器必須調(diào)整越界值使其滿足要求。編譯器會(huì)將該值對(duì) unsigned 類(lèi)型的可能取值數(shù)目求模,然后取所得值。比如 8 位的 unsigned char,其取值范圍從 0 到 255(包括 255)。如果賦給超出這個(gè)范圍的值,那么編譯器將會(huì)取該值對(duì) 256 求模后的值。例如,如果試圖將 336 存儲(chǔ)到 8 位的 unsigned char 中,則實(shí)際賦值為 80,因?yàn)?80 是 336 對(duì) 256 求模后的值。
For the unsigned types, a negative value is always out of range. An object of unsigned type may never hold a negative value. Some languages make it illegal to assign a negative value to an unsigned type, but C++ does not.
對(duì)于 unsigned 類(lèi)型來(lái)說(shuō),負(fù)數(shù)總是超出其取值范圍。unsigned 類(lèi)型的對(duì)象可能永遠(yuǎn)不會(huì)保存負(fù)數(shù)。有些語(yǔ)言中將負(fù)數(shù)賦給 unsigned 類(lèi)型是非法的,但在 C++ 中這是合法的。
|
In C++ it is perfectly legal to assign a negative number to an object with unsigned type. The result is the negative value modulo the size of the type. So, if we assign 1 to an 8-bit unsigned char, the resulting value will be 255, which is 1 modulo 256. C++ 中,把負(fù)值賦給 unsigned 對(duì)象是完全合法的,其結(jié)果是該負(fù)數(shù)對(duì)該類(lèi)型的取值個(gè)數(shù)求模后的值。所以,如果把 -1 賦給8位的 unsigned char,那么結(jié)果是 255,因?yàn)?255 是 -1 對(duì) 256 求模后的值。 |
When assigning an out-of-range value to a signed type, it is up to the compiler to decide what value to assign. In practice, many compilers treat signed types similarly to how they are required to treat unsigned types. That is, they do the assignment as the remainder modulo the size of the type. However, we are not guaranteed that the compiler will do so for the signed types.
當(dāng)將超過(guò)取值范圍的值賦給 signed 類(lèi)型時(shí),由編譯器決定實(shí)際賦的值。在實(shí)際操作中,很多的編譯器處理 signed 類(lèi)型的方式和 unsigned 類(lèi)型類(lèi)似。也就是說(shuō),賦值時(shí)是取該值對(duì)該類(lèi)型取值數(shù)目求模后的值。然而我們不能保證編譯器都會(huì)這樣處理 signed 類(lèi)型。
以上摘自 c++ primer,慚愧,還是再細(xì)細(xì)的從頭品一次這書(shū)吧。
posted on 2011-02-13 16:12 Brandon 閱讀(4978) 評(píng)論(0) 編輯 收藏 引用 所屬分類(lèi): C++

