本文主要是介绍Linux C编程——结构体操作注意事项(深拷贝、偏移量),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
在结构体中,需要考虑的有:
- 内存对齐,下面例子可以看到;
- 结构体含一级、二级指针,有深拷贝和浅拷贝之分;
- s.i和s->i是计算偏移量,在CPU中计算,不会操作内存。
有一个宏 offoset 可以计算结构体成员偏移:
SYNOPSIS#include <stddef.h>size_t offsetof(type, member);DESCRIPTIONThe macro offsetof() returns the offset of the field member from the start of the structure type.This macro is useful because the sizes of the fields that compose a structure can vary across implementa‐tions, and compilers may insert different numbers of padding bytes between fields. Consequently, an ele‐ment's offset is not necessarily given by the sum of the sizes of the previous elements.A compiler error will result if member is not aligned to a byte boundary (i.e., it is a bit field).RETURN VALUEoffsetof() returns the offset of the given member within the given type, in units of bytes.
./include/linux/stddef.h文件中有如下定义。00020: #undef offsetof
00021: #ifdef compiler_offsetof
00022: #define offsetof(TYPE,MEMBER) compiler_offsetof(TYPE,MEMBER)
00023: #else
00024: #define offsetof(TYPE, MEMBER) ((size_t) &((TYPE *)0)->MEMBER)
00025: #endif
00026: #endif /* KERNEL */
00027:
00028: #endif
#include <stddef.h>
#include <stdio.h>
#include <stdlib.h>int
main(void)
{struct s {int i;char c;double d;char a[];};/* Output is compiler dependent */printf("offsets: i=%ld; c=%ld; d=%ld a=%ld\n",(long) offsetof(struct s, i),(long) offsetof(struct s, c),(long) offsetof(struct s, d),(long) offsetof(struct s, a));printf("sizeof(struct s)=%ld\n", (long) sizeof(struct s));exit(EXIT_SUCCESS);
}
[root@localhost apue]# ./a.out
offsets: i=0; c=4; d=8 a=16
sizeof(struct s)=16
这篇关于Linux C编程——结构体操作注意事项(深拷贝、偏移量)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!