编译时的偏移量

有没有办法在编译时找到结构成员的偏移量?我希望创建一个包含结构成员偏移量的常量.在以下代码中,offsetof()宏在第一个printf语句中起作用.但是,在第10行中使用声明ofs会产生错误

“Cannot resolve ‘->’ operator as a constant expression”.

这样做还有其他方法吗?

struct MyStruct
{
   unsigned long lw;
   unsigned char c[5];
   int i;
   int j;
   unsigned long last;
};

const int ofs = offsetof(struct MyStruct,i);  // This line in error

int main(void)
{
   printf("Offset of c = %d.\n",offsetof(struct MyStruct,c) );
   printf("Offset of i = %d.\n",ofs );
   return 0;
}

解决方法

offsetof()宏是一个编译时构造.没有符合标准的方法来定义它,但每个编译器都必须有一些方法来实现它.

一个例子是:

#define offsetof( type,member ) ( (size_t) &( ( (type *) 0 )->member ) )

虽然在技术上不是编译时构造(参见用户“litb”的注释),但每个编译器必须至少有一个这样的表达式,它能够在编译时解析,这正是在&lt中定义的offsetof() ; STDDEF.H取代.

您的代码可能还有其他一些错误 – 缺少包含< stddef.h>或其他令您厌烦的编译器.

相关文章

/** C+⬑ * 默认成员函数 原来C++类中,有6个默认成员函数: 构造函数 析构函数 拷贝...
#pragma once // 1. 设计一个不能被拷贝的类/* 解析:拷贝只会放生在两个场景中:拷贝构造函数以及赋值运...
C类型转换 C语言:显式和隐式类型转换 隐式类型转化:编译器在编译阶段自动进行,能转就转,不能转就编译...
//异常的概念/*抛出异常后必须要捕获,否则终止程序(到最外层后会交给main管理,main的行为就是终止) try...
#pragma once /*Smart pointer 智能指针;灵巧指针 智能指针三大件//1.RAII//2.像指针一样使用//3.拷贝问...
目录&lt;future&gt;future模板类成员函数:promise类promise的使用例程:packaged_task模板类例程...