让我们假设我已经声明了某个数据类型的变量'i'(可能是int,char,float或double)......
注意:只需考虑声明'i',如果是int或char或float或double数据类型,则不要打扰.由于我想要一个通用的解决方案,我只是简单地提到变量'i'可以是任何一种数据类型,即int,char,float或double.
现在我可以找到没有sizeof运算符的变量'i'的大小吗?
Joã*_*lva 21
您可以使用下面的宏,取自这里:
#define sizeof_var( var ) ((size_t)(&(var)+1)-(size_t)(&(var)))
Run Code Online (Sandbox Code Playgroud)
我们的想法是使用指针arithmetic((&(var)+1))来确定变量的偏移量,然后减去变量的原始地址,从而产生其大小.例如,如果你有一个int16_t i位于变量0x0002,你将被减去0x0002从0x0006,从而获得0x4或4个字节.
但是,我没有真正看到不使用的正当理由sizeof,但我相信你必须有一个.
自从我编写任何C代码以来已经很久了,我从来都不擅长它,但这看起来是正确的:
int i = 1;
size_t size = (char*)(&i+1)-(char*)(&i);
printf("%zi\n", size);
Run Code Online (Sandbox Code Playgroud)
我相信有人可以告诉我为什么这是错误的,但它为我打印了一个合理的价值.