struct MyStruct{ int i; int j;};int main(){ struct MyStruct *p=0; int size = ((char*)(p+1))-((char*)p); printf("\nSIZE : [%d]\nSIZE : [%d]\n",size); return 0;}
为什么需要对char *进行类型转换?
如果我不使用char *指针,输出为1 – 为什么?
解决方法 因为指针算法以指向的类型为单位工作.例如:int* p_num = malloc(10 * sizeof(int)); int* p_num2 = p_num + 5;
这里,p_num2不指向超出p_num的五个字节,它指向超出p_num的五个整数.如果在您的机器上一个整数是四个字节宽,则存储在p_num2中的地址将比存储在p_num中的地址多20个字节.其原因主要是指针可以像数组一样索引. p_num [5]完全等价于*(p_num 5),所以指针算法始终以字节为单位是没有意义的,否则p_num [5]会给你一些在第二个整数中间开始的数据,而不是像你期望的那样给你第六个整数.
为了将特定数量的字节移动到指针之外,您需要将指针强制转换为指向保证恰好为1字节宽(char)的类型.
此外,您在此处有错误:
printf("\nSIZE : [%d]\nSIZE : [%d]\n",size);
您有两个格式说明符,但格式字符串后只有一个参数.
总结以上是内存溢出为你收集整理的为什么我的homespun sizeof运算符需要char * cast?全部内容,希望文章能够帮你解决为什么我的homespun sizeof运算符需要char * cast?所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)