紧急求助,一个C语言的问题
main(){inti=-5,j=0x9961,k;unsignedcharch;unsignedintu;u=i;ch=j;k=ch;printf("u=%x,u=%u...
main()
{ int i=-5,j=0x9961,k;
unsigned char ch;
unsigned int u;
u=i;
ch=j;
k=ch;
printf("u=%x,u=%u,ch=%c,k=%d\n",u,u,ch,k);
}
最终输出结果是什么,以及为什么输出的是这个结果,拜托大家帮帮忙哈
在这里先谢过 展开
{ int i=-5,j=0x9961,k;
unsigned char ch;
unsigned int u;
u=i;
ch=j;
k=ch;
printf("u=%x,u=%u,ch=%c,k=%d\n",u,u,ch,k);
}
最终输出结果是什么,以及为什么输出的是这个结果,拜托大家帮帮忙哈
在这里先谢过 展开
2个回答
展开全部
在16位编译环境中输出结果是:
u=fffb,u=65531,ch=a,k=97
在32位编译环境中输出结果则会是
u=fffffffb,u=4294967291,ch=a,k=97
同一个值,作为带符号数和无符号数,输出会不同;
不同类型的变量,由于其有效的位长不同(例如char型是8位,比int或unsigned int的有效位数少),产生类型转换时会丢弃部分数据。
以16位环境为例,int或unsigned int在16位环境下默认的位长是16位,所以带符号整数-5实际存储是二进制的 1111111111111101,即16进制的 0xfffb,赋值给无符号数u其内容也是这个0xfffb,在printf中的格式字串%x会将第一个参数u作为16进制数值输出,所以输出是0xfffb,而格式字串%u作为10进制的无符号数输出,就会输出该值对应的10进制无符号数值65531了。
int j 初值 0x9961,经 ch=j 后,因ch是字符型,有效位数是8位,所以赋值时会将高位的0x99舍弃,实际ch的数值是0x61,用格式字串%c作为字符输出,就是小写字母a;而k=ch时,因为char ch的有效位只有8位,而int k的有效位数应该是16位(对16位环境来说),因此赋值时会将k的高8位用0填充,即,k=0x0061,用格式字串%d作为10进制带符号数输出,就是97了。
u=fffb,u=65531,ch=a,k=97
在32位编译环境中输出结果则会是
u=fffffffb,u=4294967291,ch=a,k=97
同一个值,作为带符号数和无符号数,输出会不同;
不同类型的变量,由于其有效的位长不同(例如char型是8位,比int或unsigned int的有效位数少),产生类型转换时会丢弃部分数据。
以16位环境为例,int或unsigned int在16位环境下默认的位长是16位,所以带符号整数-5实际存储是二进制的 1111111111111101,即16进制的 0xfffb,赋值给无符号数u其内容也是这个0xfffb,在printf中的格式字串%x会将第一个参数u作为16进制数值输出,所以输出是0xfffb,而格式字串%u作为10进制的无符号数输出,就会输出该值对应的10进制无符号数值65531了。
int j 初值 0x9961,经 ch=j 后,因ch是字符型,有效位数是8位,所以赋值时会将高位的0x99舍弃,实际ch的数值是0x61,用格式字串%c作为字符输出,就是小写字母a;而k=ch时,因为char ch的有效位只有8位,而int k的有效位数应该是16位(对16位环境来说),因此赋值时会将k的高8位用0填充,即,k=0x0061,用格式字串%d作为10进制带符号数输出,就是97了。
TableDI
2024-07-18 广告
2024-07-18 广告
Excel一键自动匹配,在线免费vlookup工具,3步完成!Excel在线免费vlookup工具,点击4步自动完成vlookup匹配,无需手写公式,免费使用!...
点击进入详情页
本回答由TableDI提供
展开全部
结果u=fffffffb,u=4294967291,ch=a,k=97
-5的补码是1111 1111 1111 1111 1111 1111 1111 1011,“u=%x”的意思是输出十六进制数,上面的换成十六进制就是fffffffb
u=%u是输出无符号十进制整数fffffffb换成无符号整数就是4294967291
下面的同理,不过把int赋给char时会超过char的范围,产生截取现象,截取0x9961的后两位0x0061转换为十进制数就是97转换为字符就是a
-5的补码是1111 1111 1111 1111 1111 1111 1111 1011,“u=%x”的意思是输出十六进制数,上面的换成十六进制就是fffffffb
u=%u是输出无符号十进制整数fffffffb换成无符号整数就是4294967291
下面的同理,不过把int赋给char时会超过char的范围,产生截取现象,截取0x9961的后两位0x0061转换为十进制数就是97转换为字符就是a
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询