内存优化
可以通过下面的方法来改变缺省的对界条件:
· 使用伪指令#pragma pack (n),C编译器将按照n个字节对齐。
· 使用伪指令#pragma pack (),取消自定义字节对齐方式。
另外,还有如下的一种方式:
· __attribute((aligned (n))),让所作用的结构成员对齐在n字节自然边界上。如果结构中有成员的长度大于n,则按照最大成员的长度来对齐。
· __attribute__ ((packed)),取消结构在编译过程中的优化对齐,按照实际占用字节数进行对齐
typedef struct __byte_queue_t { uint8_t *pchBuffer; uint16_t hwBufferSize; uint16_t hwHead; uint16_t hwTail; uint16_t hwCount; }__byte_queue_t; //! the masked structure: the class byte_queue_t in header file typedef struct byte_queue_t { uint8_t chMask [sizeof(__byte_queue_t)] __attribute__((aligned(__alignof__(__byte_queue_t))));/*按结构体实际的情况对齐*/ } byte_queue_t;
以下代码编译出来的是以1个字节的方式对齐的,如果不这样做那么结构体将按照内存字节数最大的那个成员类型进行对齐则为4+4;1字节对齐则为5。这样能节约内存资源,但是会在效率上有所影响:
#pragma pack(n) //设置内存对齐为:1字节对齐。
struct s {
int i;
char ch;
};
#pragma pack()
(2) #pragma pack(push,1)
这是给编译器用的参数设置,有关结构体字节对齐方式的设置
大概是指把原来对齐方式设置压栈,并设新的设置为1