银河

SKYIV STUDIO

  博客园 :: 首页 :: 博问 :: 闪存 :: :: :: 订阅 订阅 :: 管理 ::
  268 随笔 :: 2 文章 :: 2616 评论 :: 140万 阅读
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

在C语言中,常用的数据类型的大小是随操作系统和编译器等因素变化的。

复制代码
 1 #include <stdio.h>
2 #include <float.h>
3
4 #define PR(x) printf("%11s: %2lu bytes\n", #x, (unsigned long)sizeof(x))
5
6 int main(void)
7 {
8 PR(size_t);
9 PR(void *);
10 PR(char);
11 PR(short);
12 PR(int);
13 PR(long);
14 PR(long long);
15 PR(float);
16 PR(double);
17 PR(long double);
18 printf("\n---- DIG -------EPSILON -----------MIN -----------MAX\n");
19 printf(" FLT %3d %-14E %-14E %-14E\n", FLT_DIG, FLT_EPSILON, FLT_MIN, FLT_MAX);
20 printf(" DBL %3d %-14E %-14E %-14E\n", DBL_DIG, DBL_EPSILON, DBL_MIN, DBL_MAX);
21 printf("LDBL %3d %-14LE %-14LE %-14LE\n", LDBL_DIG, LDBL_EPSILON, LDBL_MIN, LDBL_MAX);
22 printf("---- --- -------------- -------------- --------------\n");
23 return 0;
24 }
复制代码

这个程序在 ideone.com 中的运行结果如下所示(http://ideone.com/jH1dT):

     size_t:  4 bytes
     void *:  4 bytes
       char:  1 bytes
      short:  2 bytes
        int:  4 bytes
       long:  4 bytes
  long long:  8 bytes
      float:  4 bytes
     double:  8 bytes
long double: 12 bytes

---- DIG -------EPSILON -----------MIN -----------MAX
 FLT   6 1.192093E-07   1.175494E-38   3.402823E+38  
 DBL  15 2.220446E-16   2.225074E-308  1.797693E+308 
LDBL  18 1.084202E-19   3.362103E-4932 1.189731E+4932
---- --- -------------- -------------- --------------

实际上,这是一个 32-bit 的 linux 操作系统,编译器是 gcc 4.3.4。

这个程序在 openSuSE 12.1 64-bit 操作系统中的运行结果如下所示(编译器是 gcc 4.6.2):

     size_t:  8 bytes
     void *:  8 bytes
       char:  1 bytes
      short:  2 bytes
        int:  4 bytes
       long:  8 bytes
  long long:  8 bytes
      float:  4 bytes
     double:  8 bytes
long double: 16 bytes

---- DIG -------EPSILON -----------MIN -----------MAX
 FLT   6 1.192093E-07   1.175494E-38   3.402823E+38
 DBL  15 2.220446E-16   2.225074E-308  1.797693E+308
LDBL  18 1.084202E-19   3.362103E-4932 1.189731E+4932
---- --- -------------- -------------- --------------

上述结果中,long double 是 16 bytes 的,但是实际上其范围和精度是和 12 bytes 的是一样的,可能是在 64-bit 操作系统中为了对齐字节边界的考虑吧。

posted on   银河  阅读(3572)  评论(2编辑  收藏  举报
编辑推荐:
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
阅读排行:
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· [AI/GPT/综述] AI Agent的设计模式综述
历史上的今天:
2010-01-31 PR2打印机的串口数据线
点击右上角即可分享
微信分享提示