C++/C#跨语言编程知识点_用栈减小结构体大小和0计算偏移量_class2

cpp 复制代码
#include <iostream>
#define FIELDOFFSET(TYPE, MEMBER) (int)(&(((TYPE*)0)->MEMBER))
//0可以转换为任意类型的结构体或空对象

#pragma pack(push)
#pragma pack(1)
struct Info
{


	char username[10];//24-34 
	double userdata;//40-48
};
#pragma pack(pop)//会变成18
struct Frame
{
	unsigned char id;//0-1
	int width;//4-8
	long long height;//8-16
	unsigned char* data;//16-20
	Info info;//24-48
};
int main()
{
	int len2 = sizeof(Info);//子结构体改变
	int len = sizeof(Frame);//母结构体不改变
	int offset_w = FIELDOFFSET(Frame, width);
	int offset_h = FIELDOFFSET(Frame, height);
	int offset_d = FIELDOFFSET(Frame, data);
	int offset_i = FIELDOFFSET(Frame, info);
	/*len = sizeof(Info);*/
	
	return 0;
}

1.定义0计算偏移量

cpp 复制代码
#define FIELDOFFSET(TYPE, MEMBER) (int)(&(((TYPE*)0)->MEMBER))
int offset_w = FIELDOFFSET(Frame, width);

2.结构体入栈出栈

#pragma pack(push)

#pragma pack(1)

struct Info

{

char username[10];//24-34

double userdata;//40-48

..........

};

#pragma pack(pop)//会变成18

相关推荐
ValhallaCoder2 小时前
hot100-栈
数据结构·python·算法·
xuzhiqiang07246 小时前
Java进阶之路,Java程序员职业发展规划
java·开发语言
MediaTea6 小时前
Python:生成器表达式详解
开发语言·python
WW_千谷山4_sch6 小时前
洛谷B3688:[语言月赛202212]旋转排列(新解法:deque双端队列)
数据结构·c++·算法
Zachery Pole7 小时前
【代码随想录】二叉树
算法
漂流瓶jz7 小时前
UVA-11214 守卫棋盘 题解答案代码 算法竞赛入门经典第二版
c++·算法·dfs·aoapc·算法竞赛入门经典·迭代加深搜索·八皇后
浮生09197 小时前
DHUOJ 基础 88 89 90
算法
fpcc8 小时前
并行编程实战——CUDA编程的Enhancing Memory Allocation
c++·cuda
v_for_van8 小时前
力扣刷题记录7(无算法背景,纯C语言)
c语言·算法·leetcode
先做个垃圾出来………8 小时前
3640. 三段式数组 II
数据结构·算法