解析C语言中位字段内存分配的问题
C语言的位字段是个比较有意思的特性。它的目的是在一个机器字中保存多个对象(每个对象占据若干bit),从而节省内存资源,同时又避免复杂的位运算。在此不再讨论位字段的具体语法,下面将研究位字段的存储特性。
先说含有多个字段(field)的字(word)所占空间的规律——含有多个字段的字的大小是所有字段的类型中的最长的那个的倍数。但要确定究竟是最长类型的几倍则比较复杂,这要看是否需要考虑类型对齐问题(即一个字段能否跨越两个最长类型)。
例1:
structword{
char field1:1;
char field2:2;
int field3:4;
};
前两个字段都是char类型,第三个是int类型,所有类型中最长的是int类型。所以字的大小是int类型长度(即4字节)的倍数。而sizeofword的结果是4字节(即int的1倍),这是因为word的三个字段总共7位(1+2+4),小于int的32位,且不需考虑类型对齐问题。
例2:
structword{
char field1:1;
char field2:2;
int field3:30;
};
与上例一样,所有类型中最长的是int类型。所以字的大小是int类型长度(即4字节)的倍数。而sizeofword的结果是8字节(即int的2倍),这是因为word的三个字段总共33位(1+2+30),需要两个int的64位才能装下,且不需考虑类型对齐问题。
例3:
structword{
char field1:3;
char field2:6;
char field3:3;
};
所有类型中最长的是char类型。所以字的大小是char类型长度(即1字节)的倍数。在linux下sizeofword的结果是3字节(即char的3倍)。如果只考虑word的三个字段总共12位(3+6+3),需要两个char的16位即能装下,但是在linux的gcc实现下,第二个字段不能跨越两个char(为了对齐),所以三个字段各占一个字节。共3字节。但一个字段能否跨越两个最长类型是由具体的实现决定的。
其次,我们讨论word内各个field的存储,这个和具体的实现有关。有的是从左向右分配的,有的是从右向左分配的。这个没有规律可言。
最后,对word中的field不能进行取地址操作,这是因为指针需要对齐。但可以对word进行取地址操作。
相关文章
- 操作系统段页结合的实际内存管理--13
- 基于内存和 Redis 的两级 Java 缓存框架
- 面试题:深拷贝和浅拷贝(超级详细,有内存图)
- 数据在内存中的存储方式--C语言版
- 一文学会JVM垃圾回收器详解:串行回收,新生代内存管理内存分配
- [C语言]字符串函数与内存函数
- 【C语言进阶】整型在内存中的存储
- 【进阶】C语言——深度剖析数据在内存中的存储
- 使用shell脚本监控cpu,磁盘,内存详解程序员
- Spark内存管理详解大数据
- MySQL:如何解决内存不释放问题(mysql内存不释放)
- 内存泄漏的场景分析和避免方法总结,C语言内存泄漏详解
- Linux下如何解决C语言内存泄漏问题(c内存泄漏linux)
- “Linux小于”是什么意思?若指Linux系统系统内存小于需求,如何改善?(linux小于)
- Oracle实现内存全面优化(oracle内存全面分析)
- 势Oracle内存使用率上升一种警示信号(oracle内存使用率涨)
- 解决Oracle内存持续增大问题(oracle内存不断加大)
- C语言-内存函数的实现(二)之memmove
- C语言-内存函数的实现(一)之memcpy
- asp自带的内存缓存application
- C语言中的内存泄露怎样避免与检测
- C语言内嵌汇编API内存搜索引擎实例
- 深度剖析Java中的内存原型及工作原理
- C语言内存对齐实例详解