内存优化
可以通过下面的方法来改变缺省的对界条件:
· 使用伪指令#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
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?