64bit下 unsignd char* 和 int值相加

cc4Java 2016-08-06 10:21:28
uint32_t a = 0;
uint32_t rlen = 10;
memcpy(&a, data + rlen, sizeof(uint32_t));

data是unsignd char* 字节数组
在ios arm 32bit下, 我拷贝4个字节到 a变量中, a返回数值是正常的
在ios arm 64bit下, 我拷贝4个字节到 a变量中, a返回的值是一个非常大的值,完全不是应该拷贝的内容

是不是 64bit下 unsignd char*和int值相加做地址偏移, 有什么隐藏的转换在里面, 导致取的地址是错的?
...全文
436 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
idzeta 2016-08-30
  • 打赏
  • 举报
回复
先确定data里面的数据在64bit下是否与你期待的一致……
赵4老师 2016-08-30
  • 打赏
  • 举报
回复
理解讨论之前请先学会如何观察! 计算机组成原理→DOS命令→汇编语言→C语言(不包括C++)、代码书写规范→数据结构、编译原理、操作系统→计算机网络、数据库原理、正则表达式→其它语言(包括C++)、架构…… 对学习编程者的忠告: 多用小脑和手,少用大脑、眼睛和嘴,会更快地学会编程! 眼过千遍不如手过一遍! 书看千行不如手敲一行! 手敲千行不如单步一行! 单步源代码千行不如单步Debug版对应汇编一行! 单步Debug版对应汇编千行不如单步Release版对应汇编一行! 不会单步Release版对应汇编?在你想单步Release版C/C++代码片断的前面临时加一句DebugBreak();重建所有,然后在IDE中运行。(一般人我不告诉他!) VC调试时按Alt+8、Alt+7、Alt+6和Alt+5,打开汇编窗口、堆栈窗口、内存窗口和寄存器窗口看每句C对应的汇编、单步执行并观察相应堆栈、内存和寄存器变化,这样过一遍不就啥都明白了吗。 对VC来说,所谓‘调试时’就是编译连接通过以后,按F10或F11键单步执行一步以后的时候,或者在某行按F9设了断点后按F5执行停在该断点处的时候。 《The Intel 64 and IA-32 Architectures Software Developer's Manual》
pengzhixi 2016-08-30
  • 打赏
  • 举报
回复
我觉得不会有什么问题。你看下是不是你在把无符号字符拷贝到整形里面,自己计算的时候出错了
cc4Java 2016-08-06
  • 打赏
  • 举报
回复
这个我知道,但是64 bit和32bit指针与整形相加, 得到的地址有问题吗?这个如何解决?
paschen 版主 2016-08-06
  • 打赏
  • 举报
回复
a是什么,64位下指针是8字节,32位是4字节

64,670

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧