typedef struct some_struct printf("sizeof(unsigned long long): %d, sizeof(int): %d, \
{
int dummy;
unsigned long long some_field[];
} some_type;
int main() {
int buf;
buf = (int)&((some_type*)0)->some_field[0];
printf("buf = (int)&((some_type*)0)->some_field[0];\n");
printf("sizeof(unsigned long long): %d, sizeof(int): %d, \
sizeof(some_type): %d\n",
sizeof(unsigned long long), sizeof(int),
sizeof(some_type));
printf("buf: %d\n\n", buf);
buf = (int)&((some_type*)0)->some_field[1];
printf("buf = (int)&((some_type*)0)->some_field[1];\n");
sizeof(some_type): %d\n",
sizeof(unsigned long long), sizeof(int),
sizeof(some_type));printf("buf: %d\n\n", buf);
}
[#########################################################]
[|########################################################]
2. ((some_type*)0)->some_field[1] тут произошло смещение на 1 позицию размером в sizeof(typeof(some_field));
[#########################################################]
[#################################|#######################]
4. (int)&((some_type*)0)->some_field[1] компилятор перестал ругаться;
Вуаля, в выражении
(int)&((some_type*)0)->some_field[0]
нам не нужно знать типы структур и полей, чтобы вычислить размер памяти.