专家
公告
财富商城
电子网
旗下网站
首页
问题库
专栏
标签库
话题
专家
NEW
门户
发布
提问题
发文章
PIC单片机
XC16理解的对? 还是我理解的对?
2020-02-06 09:59
发布
×
打开微信“扫一扫”,打开网页后点击屏幕右上角分享按钮
站内问答
/
51单片机
9788
12
12
最近发现一个很有趣的事情
程序如下:
{
unsigned long I;
unsigned char J = 1000;
.
.
.
I += J*100;
}
结果呢,J*100是超出了16位的数字,但是呢,I中超出16位的进位没了!
我的理解是 这条公式里面的类型转换,也就是J*100,应该是unsigned long类型的,二不应该是unsigned int类型的。
友情提示:
此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
11条回答
leafstamen
1楼-- · 2020-02-06 10:58
J*100是8位。
加载中...
TBG3
2楼-- · 2020-02-06 14:18
精彩回答 2 元偷偷看……
加载中...
techbaby
3楼-- · 2020-02-06 19:16
觉得不对,加个强制转换不就得了!
I += (unsigned long)J*100;
加载中...
zouzhichao
4楼-- · 2020-02-06 21:25
J=1000?uchar哦
加载中...
flamma
5楼-- · 2020-02-07 03:13
unsigned char J = 1000; 这里1000就被截了
I += J*100; 这里会先转换成unsigned char,这一步就会发生截位,然后在转换成unsigned long。
反过来写 I+= 100*J 应该就不会。
加载中...
eduhf_123
6楼-- · 2020-02-07 05:23
J = 1000会被截断成J = 232,因为只能保留最低8位。
计算表达式J*100时存在整型提升,将J扩充到8*sizeof(unsigned int)位,然后再计算与100的乘积,结果为23200,因为没有超过unsigned int的取值范围,所以没有发生截断损失。
在计算+=时,先将上述的临时结果23200扩充到8*sizeof(I)位,然后计算加法。
综上,XC16没有错。
加载中...
1
2
下一页
一周热门
更多
>
相关问题
PIC单片机不同的IO口驱动74HC573驱动共阴极的数码管,有的段不亮
1 个回答
一种简单精确的pic延时方法
21 个回答
谁熟悉PIC的产品发布时间的,帮看看PIC18F47K40啥版本IDE能开发
12 个回答
求AN1078对应的源代码下载地址
5 个回答
PIC单片机应用技巧
4 个回答
串口无法连续接收数据
2 个回答
求助:dsPIC33F串口通信,如何发送字符串
4 个回答
PIC45K40 IOC(interrupt-on-change)功能
2 个回答
相关文章
一种用PIC单片机主时钟驱动的老式挂钟
0个评论
×
关闭
采纳回答
向帮助了您的网友说句感谢的话吧!
非常感谢!
确 认
×
关闭
编辑标签
最多设置5个标签!
PIC单片机
保存
关闭
×
关闭
举报内容
检举类型
检举内容
检举用户
检举原因
广告推广
恶意灌水
回答内容与提问无关
抄袭答案
其他
检举说明(必填)
提交
关闭
×
关闭
您已邀请
15
人回答
查看邀请
擅长该话题的人
回答过该话题的人
我关注的人
I += (unsigned long)J*100;
I += J*100; 这里会先转换成unsigned char,这一步就会发生截位,然后在转换成unsigned long。
反过来写 I+= 100*J 应该就不会。
计算表达式J*100时存在整型提升,将J扩充到8*sizeof(unsigned int)位,然后再计算与100的乘积,结果为23200,因为没有超过unsigned int的取值范围,所以没有发生截断损失。
在计算+=时,先将上述的临时结果23200扩充到8*sizeof(I)位,然后计算加法。
综上,XC16没有错。
一周热门 更多>