OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 4409|回复: 4

嵌入式中C语言的问题

[复制链接]

7

主题

27

帖子

0

精华

初级会员

Rank: 2

积分
75
金钱
75
注册时间
2014-5-9
在线时间
0 小时
发表于 2015-3-13 16:44:42 | 显示全部楼层 |阅读模式
5金钱
请问原子大哥,有个很简单的C语言问题,但是就是怎么也想不通
我想让0x01<<4+0x05 ,应该得到0x15,可是为什么以下有3种算法
第一种不左移4位,而是直接乘以16,得到0x15
第二种左移4位,得到0x00
第三种左移4位,但是另起一行来加上value[1],得到的也是正确的0x15
想了很久,都想不通这是为什么,请知道的指导一下,谢谢
[mw_shl_code=c,true] u8 a,b,c,d; u8 value[2] ={0x01,0x05}; a = value[0]*16 + value[1]; =0x15 b = value[0]<<4 + value[1]; =0x00 c = value[0]<<4; =0x10 d = b + value[1]; =0x15 [/mw_shl_code]

最佳答案

查看完整内容[请看2#楼]

第二种加法运算优先级大于左移,所以先执行4+value[1];然后value[0]在执行左移前面加法的结果,变成左移9位,而b是u8类型,已经溢出,所以得到0x00; 所以要得到0x15,就改成b = (value[0]<<4) + value[1];     =0x15
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

4

主题

84

帖子

0

精华

初级会员

Rank: 2

积分
155
金钱
155
注册时间
2013-10-17
在线时间
9 小时
发表于 2015-3-13 16:44:43 | 显示全部楼层
第二种加法运算优先级大于左移,所以先执行4+value[1];然后value[0]在执行左移前面加法的结果,变成左移9位,而b是u8类型,已经溢出,所以得到0x00;
所以要得到0x15,就改成b = (value[0]<<4) + value[1];     =0x15
回复

使用道具 举报

7

主题

27

帖子

0

精华

初级会员

Rank: 2

积分
75
金钱
75
注册时间
2014-5-9
在线时间
0 小时
 楼主| 发表于 2015-3-13 17:21:46 | 显示全部楼层
回复【2楼】498650771:
---------------------------------
好的,明白了,谢谢
回复

使用道具 举报

14

主题

1592

帖子

0

精华

资深版主

Rank: 8Rank: 8

积分
2622
金钱
2622
注册时间
2014-7-17
在线时间
350 小时
发表于 2015-3-13 20:51:19 | 显示全部楼层
回复【3楼】siwangqixiang:
---------------------------------
其实多点注意符号优先等级和数据类型的位数就可以啦!!!
回复

使用道具 举报

0

主题

22

帖子

0

精华

初级会员

Rank: 2

积分
124
金钱
124
注册时间
2015-3-30
在线时间
17 小时
发表于 2015-4-22 21:45:31 | 显示全部楼层
回复【2楼】498650771:
---------------------------------
精辟
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-2-23 18:20

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表