完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
各位好,请教下keil里面两个16进制数据合并成32位高16位被丢弃是什么问题呢?程序如下: 用上面的合并方式,发到串口助手里面高16位被丢弃了,需要用下面的那种合并方式.想了很久也没找到原因,求帮忙分析下,万分感谢! void main() { unsigned long along; unsigned int bu16; unsigned int cu16; bu16 = 0x1000; cu16 = 0x1010; Init_UART(); along = bu16 << 16 | cu16; UART1_Send(along >> 24); UART1_Send(along >> 16); UART1_Send(along >> 8); UART1_Send(along); ((unsigned char *)&along)[0] = bu16 >> 8; ((unsigned char *)&along)[1] = bu16 ; ((unsigned char *)&along)[2] = cu16 >> 8 ; ((unsigned char *)&along)[3] = cu16 ; UART1_Send(along >> 24); UART1_Send(along >> 16); UART1_Send(along >> 8); UART1_Send(along); while(1); } |
|
相关推荐
6个回答
|
|
along = bu16 << 16 | cu16;这里应该是
along = bu16; along = along << 16 | cu16; 按你的方法应该是bu16是16位,左移16位之后等于清零了,再把0或上cu16赋给along
最佳答案
|
|
|
|
万分感谢,有种顿悟的感觉!
|
|
|
|
楼主说的是是keil51吗,@人中狼,您说的,我并不认可,赋值给32位变量的情况下,16位变量会自动扩充到32位,左移16位之后,低16位会为0,但高16位会变为原本的数值。
mdk不会出现楼主遇到的问题,我记忆里keil51也没有这样的问题,vs也没有这样的问题。 |
|
|
|
我也好奇,我拿keil51编译器调试了一下,发现keil51的编译器是有那么一点不一样,以后遇到不同类型的赋值要小心了,比如在keil51里,像这种不同类型变量的赋值,就可以强制类型。
|
|
|
|
其实在程序里仿真一下就能看出端倪了。还好问题解决了。
|
|
|
|
我爱肖文娟 发表于 2018-1-31 18:34 这个应该不是如何强制转换的问题,应该是运算次序的问题,如果都先强制转换为32位,那就没问题,但如果是先进行移位等运算,再强制转换为32位,那就会出错了。 在这里,赋值运算应该是最后进行的,所以强制转换应该也是在赋值一刻才进行的,这样就会出错,如果在等号右边加一个强制转换的格式,例如 = (u32)等,或许也可以解决这个问题 |
|
|
|
你正在撰写答案
如果你是对答案或其他答案精选点评或询问,请使用“评论”功能。
嵌入式学习-飞凌嵌入式ElfBoard ELF 1板卡-初识设备树之设备树组成和结构
503 浏览 0 评论
【敏矽微ME32G070开发板免费体验】点亮WS2812B灯板
476 浏览 0 评论
嵌入式学习-飞凌嵌入式ElfBoard ELF 1板卡-Linux内核移植之内核启动流程
744 浏览 0 评论
嵌入式学习-飞凌嵌入式ElfBoard ELF 1板卡-TF卡烧录流程之烧写过程
1436 浏览 0 评论
2891 浏览 0 评论
【youyeetoo X1 windows 开发板体验】少儿AI智能STEAM积木平台
12144 浏览 31 评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2025-1-9 14:43 , Processed in 0.580070 second(s), Total 50, Slave 43 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号