加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

long和char []的联合,字节顺序

发布时间:2020-12-16 10:30:42 所属栏目:百科 来源:网络整理
导读:如果我在8位处理器的代码中执行以下操作: typedef union{unsigned long longn ;unsigned char chars[4];} longbytes; longbytes.chars [0]总是会成为longbytes.longn的最低字节,还是依赖于endianness / compiler / platform / target / luck等?我已经查看
如果我在8位处理器的代码中执行以下操作:

typedef union
{
unsigned long longn ;
unsigned char chars[4];
} longbytes;

longbytes.chars [0]总是会成为longbytes.longn的最低字节,还是依赖于endianness / compiler / platform / target / luck等?我已经查看了我的编译代码的反汇编,这就是我在特定情况下的情况,但我很好奇这段代码是否可移植.

解决方法

这是不可移植的原因有几个:

>这取决于您的平台(或编译器)强制执行首先写入哪个字节的字节顺序,因此您不能指望字符[0]寻址最低字节
> unsigned long不能保证与4个字符一样长,所以根据平台你甚至可能得不到完整的长(或sizeof(long)可能小于4并且你进一步阅读,但这对于8Bit处理器来说不太可能至少.
>读取一个不同的联盟成员然后你写的通常是不可移植的,它是实现定义的行为.其原因基本上是两个其他问题的结合.

总而言之,这些代码根本不可移植.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读