微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

不同内存寻址方案的C代码的可移植性

如果我理解正确,0x10c 0x10c描述了一个16位地址空间,其中每个偏移地址为16位字,而不是大多数其他存储器架构中的字节.这有一些好奇的后果,例如我想像sizeof(char)和sizeof(short)都会返回1.

将C代码保存在这种不同的存储器寻址方案之间是否可行?要记住的是什么?

编辑:也许我应该给出一个更具体的例子.假设你有一些处理字节流的网络代码.通过在每个地址只放置一个字节来丢弃一半的内存,以便代码可以保持不变,还是使用移位来概括所有内容来处理每个偏移量的N个字节?

编辑2:答案似乎关注数据类型大小的问题,这不是重点 – 我甚至不应该提到它.问题在于如何应对丢失使用指针解决内存中任何字节的能力.期望代码与此无关的是合理的吗?

解决方法

这是完全可行的.大致来说,C的基本整数数据类型的大小维持在:
sizeof (char) <= sizeof (short) <= sizeof (int) <= sizeof (long)

以上并不完全符合规格说明的要求,但它是接近的.

正如awoodland在评论中所指出的那样,您也希望Dcpu-16的C编译器具有CHAR_BIT == 16.

没有假设Dcpu-16将具有sizeof(char)== 2的奖金,这是一个常见的谬误.

原文地址:https://www.jb51.cc/c/115201.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐