Ponytai1
2016-08-20 14:51
采纳率: 25%
浏览 1.1k
已采纳

C语言中 数据类型的问题

unsigned int b=0;
b=b-1;
printf("b=%d\n",b);

unsigned char c=0;
c=c-1;
printf("c=%d\n",c);

为什么b=-1;c=255;   ?

据我理解,计算机b,c在内存中应该都是全1.并且输出格式都是%d都有符号,所以
1111111.。。都应该表示为-1,为什么c是255??

  • 写回答
  • 好问题 提建议
  • 关注问题
  • 收藏
  • 邀请回答

5条回答 默认 最新

  • wenglqq 2016-08-21 03:18
    已采纳

    正是因为是%d,所以才会有这个情况,%d会把参数以整型输出,而255,是1111 1111,它转换为整型,并没有超出整型的表示范围,不会溢出为-1

    已采纳该答案
    评论
    解决 无用
    打赏 举报
  • jehovahx 2016-08-20 14:58

    char只有一个字节,int至少16位

    评论
    解决 无用
    打赏 举报
  • Hallo_ween 2016-08-20 15:30

    在不同平台char型的不一样,有的编译器是一个字节有的是两个字节,当超出范围是像127+1就是-128了这根他第一位是符号位有关,你好好分析一下他的取值范围是怎么来的问题就迎刃而解了

    评论
    解决 无用
    打赏 举报
  • threenewbee 2016-08-20 15:40

    %d是将参数当成整数,因此会对unsigned char转换成int,c本来就是255,int足够大,转换后不发生溢出,还是255
    int main()
    {
    unsigned char c=0;
    c=c-1;
    printf("c=%d\n",(char)c);
    }
    这样会造成c的溢出,才能输出-1

    评论
    解决 无用
    打赏 举报
  • kaijian1226 2016-08-20 15:52

    假如int为16bit,第二行得到 b = 2^16 -1,第三行就是强制转换,类似于(int)b ,所以输出-1;而第二个程序,第二行得到 c = 2^8 -1 = 255,强制转换(int)c,得到的就是255

    评论
    解决 无用
    打赏 举报

相关推荐 更多相似问题