#pragma pack(push)让编译器将当前对齐状态保存下来
#pragma pack(pop) 让编译器恢复保存的状态
#pragma pack(n) 让编译器按照n字节对齐
#include <stdio.h>
#define CLASS(a) typedef struct a a; \
struct a{ \
a##_FIELDS; \
};
#define ALIGN_SET(n) __pragma(pack(push, n))
#define ALIGN_REC __pragma(pack(pop))
#define Base_FIELDS \
int base_int;\
char base_char;
ALIGN_SET(1)
CLASS(Base)
ALIGN_REC
#define Private_FIELDS Base_FIELDS \
int private_int; \
char private_char;
CLASS(Private)
int main(void)
{
Base b;
Private c;
printf("%d\n", sizeof(b));
printf("%d\n",sizeof(c));
printf("yeap\n");
}
sizeof(b)输出为5,说明设置1字节对齐成功,sizeof(c)输出为16,说明恢复默认的4字节对齐成功。(代码参考https://www.cnblogs.com/yangguang-it/p/7392726.html)
此处用宏想试试如何模拟c++的继承,代码参考(https://blog.youkuaiyun.com/hdujinhuihui/article/details/8393231)
#define LOG(...) {FILE*fp = fopen("log.txt","a+"); fprintf(fp,__VA_ARGS__); fclose(fp);}
//使用...和__VA_ARGS__来替代可变参数