struct中的offset位置计算的问题

win1naruto 2019-03-21 03:24:21

struct Node {
int val;
//int va;
//short b;
//int vb;
Node* next;
Node() { // 初始化节点
val = -1;
next = NULL;
}
};

Node solid;
cout << ((unsigned int)&(solid.next) - (unsigned int)&solid )<< endl;


我这是64位机器,一个int是4字节.
也就是next的地址 - 第一个int的地址=8. 我的问题是为什么不是4 ??
如果是2个int, next的地址相对于offset也是8:
int val;
int va;
*next

就我原始的这个struct,其实不存在对齐问题,int, 4字节,下面的Node*, 指针 ,也是4字节啊...
...全文
146 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
赵4老师 2019-03-21
  • 打赏
  • 举报
回复
#include <stdio.h>
#define field_offset(s,f) (int)(&(((struct s *)(0))->f))
struct AD  { int a; char b[13]; double c;};
#pragma pack(push)
#pragma pack(1)
struct A1  { int a; char b[13]; double c;};
#pragma pack(2)
struct A2  { int a; char b[13]; double c;};
#pragma pack(4)
struct A4  { int a; char b[13]; double c;};
#pragma pack(8)
struct A8  { int a; char b[13]; double c;};
#pragma pack(16)
struct A16 { int a; char b[13]; double c;};
#pragma pack(pop)
int main() {
    printf("AD.a %d\n",field_offset(AD,a));
    printf("AD.b %d\n",field_offset(AD,b));
    printf("AD.c %d\n",field_offset(AD,c));
    printf("AD sizeof %d\n", sizeof(AD));
    printf("\n");
    printf("A1.a %d\n",field_offset(A1,a));
    printf("A1.b %d\n",field_offset(A1,b));
    printf("A1.c %d\n",field_offset(A1,c));
    printf("A1 sizeof %d\n", sizeof(A1));
    printf("\n");
    printf("A2.a %d\n",field_offset(A2,a));
    printf("A2.b %d\n",field_offset(A2,b));
    printf("A2.c %d\n",field_offset(A2,c));
    printf("A2 sizeof %d\n", sizeof(A2));
    printf("\n");
    printf("A4.a %d\n",field_offset(A4,a));
    printf("A4.b %d\n",field_offset(A4,b));
    printf("A4.c %d\n",field_offset(A4,c));
    printf("A4 sizeof %d\n", sizeof(A4));
    printf("\n");
    printf("A8.a %d\n",field_offset(A8,a));
    printf("A8.b %d\n",field_offset(A8,b));
    printf("A8.c %d\n",field_offset(A8,c));
    printf("A8 sizeof %d\n", sizeof(A8));
    printf("\n");
    printf("A16.a %d\n",field_offset(A16,a));
    printf("A16.b %d\n",field_offset(A16,b));
    printf("A16.c %d\n",field_offset(A16,c));
    printf("A16 sizeof %d\n", sizeof(A16));
    printf("\n");
    return 0;
}
//AD.a 0
//AD.b 4
//AD.c 24
//AD sizeof 32
//
//A1.a 0
//A1.b 4
//A1.c 17
//A1 sizeof 25
//
//A2.a 0
//A2.b 4
//A2.c 18
//A2 sizeof 26
//
//A4.a 0
//A4.b 4
//A4.c 20
//A4 sizeof 28
//
//A8.a 0
//A8.b 4
//A8.c 24
//A8 sizeof 32
//
//A16.a 0
//A16.b 4
//A16.c 24
//A16 sizeof 32
//
//
林多 2019-03-21
  • 打赏
  • 举报
回复
64位的机器上,指针是8占个字节的。 32位的机器上,指针占4个字节。 你可以把,int val,换成 char val。。。结果一样是8(字节对齐)。 这样就一目了然了。
A-De 2019-03-21
  • 打赏
  • 举报
回复


引用 2 楼 win1naruto 的回复:
[quote=引用 1 楼 A-De 的回复:]
内存对齐,机嚣和编译器决定的,可以修改的

#if defined( __GNUC__ )
# pragma pack(1)
#else
# pragma pack(push,1)
#endif

struct Node {
...
};

#if defined( __GNUC__ )
# pragma pack()
#else
# pragma pack(pop)
#endif

把结构体用你的东西包起来 的确和我预想的结果一样了..
你能告诉我一下你包起来的东西什么意思??
谢谢~[/quote]

https://blog.csdn.net/aidem_brown/article/details/77540527
win1naruto 2019-03-21
  • 打赏
  • 举报
回复
引用 1 楼 A-De 的回复:
内存对齐,机嚣和编译器决定的,可以修改的 #if defined( __GNUC__ ) # pragma pack(1) #else # pragma pack(push,1) #endif struct Node { ... }; #if defined( __GNUC__ ) # pragma pack() #else # pragma pack(pop) #endif
把结构体用你的东西包起来 的确和我预想的结果一样了.. 你能告诉我一下你包起来的东西什么意思?? 谢谢~
A-De 2019-03-21
  • 打赏
  • 举报
回复
内存对齐,机嚣和编译器决定的,可以修改的

#if defined( __GNUC__ )
# pragma pack(1)
#else
# pragma pack(push,1)
#endif

struct Node {
...
};

#if defined( __GNUC__ )
# pragma pack()
#else
# pragma pack(pop)
#endif

64,654

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧