如何解决C 中为浮点数分配的内存大小
#include <stdio.h>
#define max_size 100
float array[max_size];
int n,counter;
int main(){
printf("Enter the size of the array...\n");
scanf("%d",&n);
for (counter=0; counter<n; counter++){
printf("%p\t",&array[counter]);
}
printf("\n\n");
return 0;
}
我只是在试验这个 C 程序,我正在尝试验证浮点数的大小是否为 8 个字节。但是在使用数组中的 5 个元素运行此代码时,我得到这些元素的地址如下:
Enter the size of the array...
5
0x555555755040 0x555555755044 0x555555755048 0x55555575504c 0x555555755050
正如你所看到的第一个浮点数,我的系统已经分配了内存空间 ...40,41,42,43 如果我没记错的话,这是 4 位的空间。但是 float 数据类型应该有 8 个字节的空间。我认为该程序应该为 2 个字节的空间分配内存空间 ...40,...4F。所以
...40-...4F //for first 2 bytes
...50-...5F //for second 2 bytes
...60-...6F //for third 2 bytes
...70-...7F //for last 2 bytes
所以第二个地址将从 ...80 开始。但这不是我得到的结果。在这个过程中我缺少什么?谢谢你的帮助!!
解决方法
C 标准对 float
的存储大小没有任何说明,它被故意忽略给实现者。
也许在您的系统和编译器上,大小是 4。您可以使用 sizeof(float)
来检查。另见this discussion。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。