c语言中unsigned int 和 int之间是怎么转化的?之间有什么区别?下面的题目麻烦详解下,谢谢~
main(){unsignedinta=65535;intb=-2;printf("%d,%o,%x,%u,%u",a,a,a,a,b);}答案是-1,177777,ff...
main()
{unsigned int a=65535;
int b=-2;
printf("%d,%o,%x,%u,%u",a,a,a,a,b);}
答案是 -1,177777,ffff,65535,65534 展开
{unsigned int a=65535;
int b=-2;
printf("%d,%o,%x,%u,%u",a,a,a,a,b);}
答案是 -1,177777,ffff,65535,65534 展开
1个回答
展开全部
首先你应该int类型的数都是用补码表示的吧?
比如-1,-2的原码分别是
1000000000000001
1000000000000010(原码最高位为符号位1表示负,0表示正)
反码就分别是
1111111111111110
1111111111111101(反码是在原码基础上除了符号位以外全部取反)
补码就分别是
1111111111111111
1111111111111110(补码是在反码基础上加1)
而unsigned int就是简单的权值相加
所以无符号的65535表示成
1111111111111111
所以用%d输出的时候就输出有符号整数,就是-1了。
%u,%x分别是八进制和十六进制,转化下就知道了。
%u输出-2的时候就是把1111111111111110当成无符号数输出简单计算了下就知道是65534了。
你一分都没给,回答你这个问题纯粹是兴趣使然。
比如-1,-2的原码分别是
1000000000000001
1000000000000010(原码最高位为符号位1表示负,0表示正)
反码就分别是
1111111111111110
1111111111111101(反码是在原码基础上除了符号位以外全部取反)
补码就分别是
1111111111111111
1111111111111110(补码是在反码基础上加1)
而unsigned int就是简单的权值相加
所以无符号的65535表示成
1111111111111111
所以用%d输出的时候就输出有符号整数,就是-1了。
%u,%x分别是八进制和十六进制,转化下就知道了。
%u输出-2的时候就是把1111111111111110当成无符号数输出简单计算了下就知道是65534了。
你一分都没给,回答你这个问题纯粹是兴趣使然。
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询