紧急求助,一个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);
}

最终输出结果是什么,以及为什么输出的是这个结果,拜托大家帮帮忙哈
在这里先谢过
展开
 我来答
davidrin
2010-03-14 · TA获得超过1788个赞
知道小有建树答主
回答量:718
采纳率:100%
帮助的人:803万
展开全部
在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了。
TableDI
2024-07-18 广告
Excel一键自动匹配,在线免费vlookup工具,3步完成!Excel在线免费vlookup工具,点击4步自动完成vlookup匹配,无需手写公式,免费使用!... 点击进入详情页
本回答由TableDI提供
弓月弹流星
2010-03-14 · 超过18用户采纳过TA的回答
知道答主
回答量:59
采纳率:0%
帮助的人:49.4万
展开全部
结果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
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式