为何signed char和unsigned char x=-1printf("%d\n",x)

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了为何signed char和unsigned char x=-1printf("%d\n",x)相关的知识,希望对你有一定的参考价值。

为什么C++中signed char x=-1和unsigned char x=-1用printf("%d\n",x)输出一个是-1,一个是255?

参考技术A -1在存储时,第一位是符号位,-用1表示,负数用补码存储,因此-1,存储的时候计为11111111。第一个有符号,读出为-1;第二个为无符号,此时8位都为数字位,读为255。 参考技术B 因为声明的时候两个变量一个是有符号数一个是无符号数,大小范围分别是-128~127和0~255(char的大小是1个字节,8bit)
-1的二进制码是11111111,对应用无符号数(第二个变量)的格式解析大小就是255了追问

 那signed char x=-1 ;printf("%d\n",x);输出时是按补码转换成十进制还是并不是这样?

追答

%d就是表示按十进制输出

追问

我的疑问就是unsigned char x=-1 ;printf("%d\n",x);输出时是按补码转换成十进制的,可是signed char x=-1 ;printf("%d\n",x);输出是-1,如果按补码来按十进制输出不应该是-127吗?

追答

额,signed char x=-1输出就是-1啊……你可以搜索一下知道补码如何求真值
就是11111111先求反码再+1,得到00000001,所以值是-1

追问

好的谢谢

本回答被提问者采纳
参考技术C signed char x表示有符号字符型,能表示的范围-128~127
unsigned char x表示无符号字符型,能表示的范围0~255
二进制中-1是以补码形式存在,解释成无符号整,正好是255追问

 那signed char x=-1 ;printf("%d\n",x);输出时是按补码转换成十进制还是并不是这样?

unsigned/signed int/char类型表示的数值范围

一个32位的signed int类型整数表示的范围:-2^31~2^31-1

一个32位的unsigned int类型整数表示的范围: 0~2^32-1

 

一个8位的signed char类型整数表示的范围:-2^7~2^7-1

一个8位的unsigned char类型整数表示的范围: 0~2^8-1

 

示例:

1
2
3
4
5
6
7
8
9
10
11
int main()
{
    char a[1000];
    int i = 0;
    for(i=0; i<1000; i++)
    {
         a[i] = -1 - i;
    }
    printf("%d "strlen(a));
    return 0;
}

 

答案:255

分析:

当i的值为0时,a[0]的值为-1,关键就是-1在内存是如何存储的。

我们知道,在计算机内部数值一律使用补码存储。正数的补码与原码一致,负数的补码是符号位为1,其余位是该负数的绝对值按位取反后加1得到。

按照负数的补码规则,可以知道-1的补码是0xff,-2的补码是0xfe。。。当i的值为127的时候,a[127]的值为-128,是char能表示的最小的数值。当i=129时,a[128]=-129,这时候发生溢出,-129需要9位才能保存下来,但是char的类型数据只有8位,所以最高位被丢弃,剩下的8位是原来9位补码的低8位,为1000 0000,当i增加到255时候,a[255]=-256,-256的补码的低8位是0000 0000,然后i=256时,a[256]=-257的补码低8位为1111 1111,由此开始新一轮的循环。。。。

按照上面的分析,a[0]---a[254]的值都不为0,而a[255]的值为0,strlen函数是计算字符串长度的,并不包含字符串最后的‘‘。所以strlen(a)=255.

 

 

那么,+0和-0在内存是如何存储的呢?

十进制          原码            反码          补码

 +0         0000 0000    0000 0000   0000 0000

 -0        10000 0000    1111 1111   0000 0000

以上是关于为何signed char和unsigned char x=-1printf("%d\n",x)的主要内容,如果未能解决你的问题,请参考以下文章

为何signed char和unsigned char x=-1printf("%d\n",x)

unsigned和signed char

unsigned char 和 signed char 区别

C语言 请问signed char,unsigned char,short,unsigned sh

将 unsigned char 转换为 signed char 以获得红黑树

在C语言中,unsigned char是啥类型