我是靠谱客的博主 要减肥柜子,最近开发中收集的这篇文章主要介绍linux内核 数据类型,linux内核数据类型详分析,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

77a3cc901a1769c5e0b7aae16b0c6a03.png

数据对齐

编写可移植代码而值得考虑的最后一个问题是如何访问未对齐的数据。存取不对齐的数据应当使用下列宏:

77f5229ee2eb19ebfb1bc19f5e63d4f1.png

这些宏是无类型的,并对各总数据项,不管是 1、2、4或 8 个字节,他们都有效,并且在所有内核版本中都有定义。

关于对齐的另一个问题是数据结构的跨平台移植性。同样的数据结构在不同的平台上可能被不同地编译。为了编写可以跨体系移植的数据结构,应当始终强制数据项的自然对齐。自然对齐(natural alignment)指的是:数据项大小的整数倍的地址上存储数据项。应当使用填充符避免强制自然对齐时编译器移动数据结构的字段,在数据结构中留下空洞。

dataalign 程序实验展示了编译器如何强制对齐。

为了目标处理器的良好性能,编译器可能悄悄地插入填充符到结构中,来保证每个成员是对齐的。若定义一个和设备要求的结构体相匹配结构,自动填充符会破坏这个意图。解决这个问题的方法是告诉编译器这个结构必须是"紧凑的", 不能增加填充符。例如下列的定义:

a3e955bc0886b95f874da4ec123ef3a9.png

最后

以上就是要减肥柜子为你收集整理的linux内核 数据类型,linux内核数据类型详分析的全部内容,希望文章能够帮你解决linux内核 数据类型,linux内核数据类型详分析所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(52)

评论列表共有 0 条评论

立即
投稿
返回
顶部