计算结构体中成员变量的偏移

被人问到这个问题,各种解决。

google一下,MFC中有一个OFFSET宏,就有这个功能。

写一下:

#define offsetof(structure, member) ((int)(&((structure *)0)->member))

eg:

#include <iostream>
using namespace std;
#include <stdio.h>
#define offsetof(structure, member) ((int)(&((structure *)0)->member))

struct test_struct
{
	int a;
	char b;
	int aa[10];
	char bb[2];
};

int main()
{
	cout<<offsetof(struct test_struct, a)<<endl;
	cout<<offsetof(struct test_struct, b)<<endl;
	cout<<offsetof(struct test_struct, aa)<<endl;
	cout<<offsetof(struct test_struct, bb)<<endl;
	return 0;
}

  

时间: 2024-11-07 20:01:15

计算结构体中成员变量的偏移的相关文章

遍历结构体中的变量

public struct Site  {  [MarshalAs(UnmanagedType.ByValTStr, SizeConst = 30)]  public string Country;     [MarshalAs(UnmanagedType.ByValTStr, SizeConst = 10)]  public string StationNumber;     [MarshalAs(UnmanagedType.ByValTStr, SizeConst = 20)]  publi

结构体访问成员变量什么时候该用“-&gt;”或者是&quot;.&quot;呢?的困惑

煎蛋栗子: typedef struct Node{int data;struct Node *next;}LinkList; LinkList *p=(LinkList *)malloc(sizeof(LinkList)); 在这里,变量p是[LinkList *]类型的[指针变量]它的值是指向某一个[结点]的[地址] 而[(*p)]表示的则是[结点变量],它的值指向的是一个[结点]p是指针,(*p)是结点变量.我们要访问结构体内的成员data 通过指针变量访问:[p]->data通过结点变量

结构体中某字段的偏移值

1.头文件 #include <stddef.h> 2. size_t offsetof(结构体名, 字段名); 举例子: size_t iOffset = offsetof(IMAGE_DOS_HEADER, e_lfanew); 3.

结构体中定义函数指针

转自:http://blog.csdn.net/unix21/article/details/9293877 结构体指针变量的定义,定义结构体变量的一般形式如下: 形式1:先定义结构体类型,再定义变量 struct结构体标识符 { 成员变量列表;… }; struct 结构体标识符 *指针变量名; 变量初始化一:struct结构体标识符 变量名={初始化值1,初始化值2,…, 初始化值n }; 形式2:在定义类型的同时定义变量 struct结构体标识符 { 成员变量列表;… } *指针变量名;

当结构体遇上宏定义,以及函数指针的高级写法(结构体中能用宏定义一个函数?)

一.结构体中可以定义一般的宏定义 如: struct aaa{   #define STATUS_1 100   #define STATUS_2 200   #define STATUS_3 300   ........}: 首先,这里的宏定义是在预编译阶段完成的,编译器此时并不知道什么结构体,所以这些宏是全局可见的.   一个宏定义,如果写在结构体之内,即使与结构体之外的宏定义名字重复了最多是编译警告.可是如果不在结构体之内,名字重复可肯定是error.(未证实,可以做实验,而且可以把两处的

如何知道结构体中某个成员相对结构体开始的偏移

#include <stdio.h>#define STRUCT_OFFSET(stru_name, element) (unsigned long)&((struct stru_name*)0)->elementstruct stru_addr{    int a;    char b;    int d;    char c; }; int main(void){    struct stru_addr s;    printf("start addr of s =

libev 中 ev_loop 结构体中的成员变量

1.ev_loop是libev用来描述事件循环的结构体.在libev中的定义比较绕,这里把它摘抄出来,做下注释,方便学习.libev的定义如下 struct ev_loop { ev_tstamp ev_rt_now; #define ev_rt_now ((loop)->ev_rt_now) #define VAR(name,decl) decl; #include "ev_vars.h" #undef VAR }; #include "ev_wrap.h"

C语言 结构体中的成员域偏移量

//C语言中结构体中的成员域偏移量 #define _CRT_SECURE_NO_WARNINGS #include<stdio.h> #include<stdlib.h> #include<string.h> typedef struct _student{ char name[30];//32 int num; }Student; void main(){ Student *p = NULL; printf("%x\n", p);//打印 0 p

结构体中最后一个成员为[0]或[1]长度数组(柔性数组成员)的用法

结构体中最后一个成员为[0]长度数组的用法:这是个广泛使用的常见技巧,常用来构成缓冲区.比起指针,用空数组有这样的优势:(1).不需要初始化,数组名直接就是所在的偏移:(2).不占任何空间,指针需要占用int长度空间,空数组不占任何空间.“这个数组不占用任何内存”,意味着这样的结构节省空间:“该数组的内存地址就和它后面的元素地址相同”,意味着无需初始化,数组名就是后面元素的地址,直接就能当指针使用. 这样的写法最适合制作动态buffer,因为可以这样分配空间malloc(sizeof(struc