(1)各种数据类型在16位、32位和64位系统下所占字节差异简介(2)各种数据类型的输出控制符

本文详细解析了C/C++中各种数据类型的内存占用情况,对比了16位、32位和64位系统下的差异,并深入探讨了输出控制符的使用,包括标志位、输出最小宽度、精度和长度等关键概念。

参考:
链接:https://blog.youkuaiyun.com/liu1055087125/article/details/66478048

一、各种数据

编写C、C++程序时需要考虑每种数据类型在内存中所占的内存大小,即使同一种数据类型在不同平台下所占内存大小亦不相同,具体对比如下:

数据类型16位系统(byte)32位系统(byte)64位系统(byte)备注
char111
short 、unsigned short222
int、unsigned int244
long、unsigned long448
float444
double888
long long888
long double10/1210/16有效位10字节。32位为了对齐实际分配12字节;64位分配16字节
指针248

二、输出控制符

http://c.biancheng.net/cpp/html/33.html
文章目录
C语言输出格式控制符汇总
0.格式字符串通用格式

  1. 标志位
    2.输出最小宽度
    3.精度
    4.长度
    5.类型 (由于经常用,所以放在了前面)

5.类型

类型字符用以表示输出数据的类型,其格式符和意义如下表所示:

格式字符意义
d以十进制形式输出带符号整数(正数不输出符号)
o以八进制形式输出无符号整数(不输出前缀0)
x,X以十六进制形式输出无符号整数(不输出前缀Ox)
u以十进制形式输出无符号整数
f以小数形式输出单、双精度实数
e,E以指数形式输出单、双精度实数
g,G以%f或%e中较短的输出宽度输出单、双精度实数
c输出单个字符
s输出字符串

这个不予演示。

0.格式字符串通用格式

在Turbo C中格式字符串的一般形式为:

[标志] [输出最小宽度] [.精度] [长度] 类型
其中方括号[]中的项为可选项。

1. 标志位

标 志 意义

  • 结果左对齐,右边填空格
  • 输出符号(正号或负号)
    空格 输出值为正时冠以空格,为负时冠以负号
    #对c、s、d、u类无影响; 对o类,在输出时加前缀o; 对x类,在输出时加前缀0x; 对e、g、f 类当结果有小数时才给出小数点。
    演示:

在这里的左对齐的演示和第二部分最小宽度放在一起.

int a = -100, b = 101;
printf("%+d|%+d|\n", a, b);
/输出结果
-100|+101| //将符号也输出出来了
*********************/

int a = 100, b = -101;
printf("|% d|% d|\n", a, b);
/输出结果
| 100|-101|//注意到100前面有个空格 正数符号用空格表示 负数直接输出符号
*********************/

int a = 100;
float b = 99.99, c = 99;
printf("%x|%f|\n", a, b);//%x 表示以十六进制输出这个数
printf("%#x|%#f|\n", a, b);
/输出结果
64|99.989998|
0x64|99.989998|//注意前缀
*********************/

2.输出最小宽度

用十进制整数来表示输出的最少位数。若实际位数多于定义的宽度,则按实际位数输出,若实际位数少于定义的宽度则补以空格或0。

int a=100,b=101,c=102;
printf("%6d|%6d|%6d|\n",a,b,c);//每一个数字占6位 不足处补空格 注意printf是默认右对齐
printf("%-6d|%-6d|%-6d|",a,b,c);//- 标志位表示左对齐,右边不足的地方补空格
/输出结果
100| 101| 102|//第一行默认右对齐 左边补空格
100 |101 |102 |//第二行-表示 左对齐 右边补空格
*********************/

3.精度

精度格式符以“.”开头,后跟十进制整数。
本项的意义是:

如果输出数字,则表示小数的位数;
如果输出的是字符,则表示输出字符的个数;
若实际位数大于所定义的精度数,则截去超过的部分。
演示:

char a[]=“abcdef”;
float b = 99.12345, c = 99;
printf("%s|%f|%f\n", a, b, c);//正常输出
printf("%.5s|%.3f|%.2f\n", a, b, c);//控制字符长度 以及小数位数
/输出结果
abcdef|99.123451|99.000000
abcde|99.123|99.00 //字符串a只输出了前5位 后面两个小数都被控制了小数位数
*********************/

4.长度

长度格式符为h、l两种,h表示按短整型量输出,l表示按长整型量输出。

long int a = 270000000;
printf(“long int = %d;int = %d.\n”,sizeof(long int),sizeof(int));
printf("|%d|%d|%d|\n",a,a,a);
printf("|%hd|%ld|%d|",a,a,a);
/输出结果
long int = 4;int = 4.//在笔者电脑上两个编译器long int的实现的长度都和int 一致 所以这里%d 和%ld 都还可以的 但是在其他电脑上就不一定了
|270000000|270000000|270000000|
|-8320|270000000|270000000| //短整型时出错了
*********************/

<think>好的,用户想了解C语言中不同数据类型字节大小、存储方式读取方法。首先,我需要整理C语言的基本数据类型及其对应的字节数。根据引用[2],常见的类型包括char(1字节)、short(2)、int(4)、long(4或8)、long long(8)、float(4)、double(8)等。需要注意的是,不同编译器系统下可能会有差异,比如long类型在3264系统中可能不同。 接下来是存储方式。用户提到了大小端模式,这在引用[1][4]中有详细说明。大端是高字节在前,小端是低字节在前。例如,int 0x12345678在大端下存储为12 34 56 78,而小端则是78 56 34 12。需要解释这两种模式的区别以及它们对多字节数据类型存储的影响。 然后是读取方法。引用[3]提到了使用fscanf等函数进行文件操作,但这里可能更关注如何从内存中读取不同数据类型的数据。例如,通过指针类型转换来访问特定类型的值,比如将char指针转换为int指针读取整型数据。同时需要注意对齐问题,不同数据类型可能有不同的对齐要求,影响内存访问效率。 比较部分需要总结不同数据类型的特点,比如数值范围、精度、存储效率等。例如,char适合存储字符但范围有限,int适合整数运算,floatdouble用于浮点数但有精度差异。此外,还要考虑不同场景下的选择,如内存紧张时使用较小类型,需要高精度时使用double。 用户可能的问题包括如何检测当前系统的大小端模式,不同数据类型的取值范围如何计算,以及类型转换时的注意事项。这些问题需要在相关部分提及,并给出示例或解决方法。 最后,确保回答符合格式要求,行内公式用$,独立公式用$$,正确引用来源。同时生成的相关问题要围绕数据类型、存储读取展开,帮助用户深入理解。</think>### C语言数据类型详解 #### 一、数据类型字节大小 C语言常见数据类型及其字节大小如下: 1. **基本类型**: - `char`:1字节(字符型) - `short`:2字节(短整型) - `int`:4字节(整型) - `long`:4字节32系统)或8字节64系统) - `long long`:8字节(长长整型) - `float`:4字节(单精度浮点型) - `double`:8字节(双精度浮点型)[^2] 2. **特殊类型**: - 指针类型:4字节32系统)或8字节64系统) - 枚举类型(`enum`):与`int`大小相同 - `void`:无大小,仅用于函数返回值指针 > 注意:字节大小可能因编译器系统架构不同而有所差异。可通过`sizeof()`运算符验证具体环境中的值,例如: > ```c > printf("int size: %zu\n", sizeof(int)); // 输出4或8 > ``` --- #### 二、存储方式 1. **内存对齐**: 数据在内存中按特定规则对齐以提升访问效率。例如: - `int`(4字节)通常按4字节对齐 - `double`(8字节)按8字节对齐 2. **字节序(大小端模式)**: - **大端模式**(Big Endian):高字节存储在低地址,如`0x12345678`存储为`12 34 56 78`[^1] - **小端模式**(Little Endian):低字节存储在低地址,如`0x12345678`存储为`78 56 34 12`[^4] 可通过以下代码检测系统字节序: ```c int num = 0x12345678; char *p = (char *)# if (*p == 0x78) printf("Little Endian"); ``` 3. **浮点数存储**: - 采用IEEE 754标准,例如`float`的存储结构为: $$ (-1)^s \times (1 + \text{尾数}) \times 2^{\text{指数}-127} $$ 其中`s`为符号,尾数23,指数8 --- #### 三、数据读取方法 1. **直接内存访问**: ```c int a = 10; char *ptr = (char *)&a; // 按字节访问整型数据 ``` 2. **文件读取**: - 使用`fread`按数据类型读取二进制文件: ```c FILE *fp = fopen("data.bin", "rb"); int arr[10]; fread(arr, sizeof(int), 10, fp); // 读取10个int类型数据 ``` - 使用`fscanf`格式化读取文本文件: ```c int num; fscanf(fp, "%d", &num); // 读取整型数据[^3] ``` 3. **类型转换**: - 显式转换:`double d = (double)10;` - 隐式转换:`int a = 3.14;`(自动截断为3) --- #### 四、数据类型比较 | 数据类型 | 字节数 | 数值范围(示例) | 适用场景 | |-----------|--------|------------------------|------------------------| | `char` | 1 | -128~127 | ASCII字符存储 | | `short` | 2 | -32768~32767 | 节省空间的整数存储 | | `int` | 4 | -2³&sup1;~2³&sup1;-1 | 通用整数运算 | | `float` | 4 | ±3.4e-38~3.4e38 | 单精度浮点计算 | | `double` | 8 | ±1.7e-308~1.7e308 | 高精度科学计算 | ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值