# C数据类型
在 C 语言中,数据类型指的是用于声明不同类型的变量或函数的一个广泛的系统。变量的类型决定了变量存储占用的空间,以及如何解释存储的位模式。
C 中的类型可分为以下几种:
| 序号 | 类型与描述 |
| --- | --- |
| 1 | 基本类型:它们是算术类型,包括两种类型:整数类型和浮点类型 |
| 2 | 枚举类型:它们也是算术类型,被用来定义在程序中只能赋予其一定的离散整数值的变量。 |
| 3 | void 类型:类型说明符 void 表明没有可用的值。 |
| 4 | 派生类型:它们包括:指针类型、数组类型、结构类型、共用体类型和函数类型。 |
>[danger]数组类型和结构类型统称为聚合类型。函数的类型指的是函数返回值的类型。在本章节接下来的部分我们将介绍基本类型,其他几种类型会在后边几个章节中进行讲解。
## 整数类型
下表列出了关于标准整数类型的存储大小和值范围的细节:
| 类型 | 存储大小 | 值范围 |
| --- | --- |--- |
| char | 1 字节 |-128 到 127 或 0 到 255|
| unsigned char | 1 字节 |0 到 255|
| signed char | 1 字节 |-128 到 127|
| int | 2 或 4 字节 |-32,768 到 32,767 或 -2,147,483,648 到 2,147,483,647|
| unsigned int | 2 或 4 字节 |0 到 65,535 或 0 到 4,294,967,295|
| short | 2 字节 |-32,768 到 32,767
| unsigned short | 2 字节 |0 到 65,535|
| long | 4 字节 |-2,147,483,648 到 2,147,483,647|
| unsigned long | 4 字节 |0 到 4,294,967,295|
注意,各种类型的存储大小与系统位数有关,但目前通用的以64位系统为主。
以下列出了32位系统与64位系统的存储大小的差别(windows 相同):
![](https://img.kancloud.cn/3e/97/3e972e44a6fb3b73a1b349190cb48242_808x654.jpg)
为了得到某个类型或某个变量在特定平台上的准确大小,您可以使用**sizeof**运算符。表达式*sizeof(type)*得到对象或类型的存储字节大小。下面的实例演示了获取 int 类型的大小:
实例
```
#include <stdio.h>
#include <limits.h>
int main() {
printf("int 存储大小 : %lu \\n", sizeof(int));
return 0;
}
```
**%lu**为 32 位无符号整数,详细说明查看[C 库函数 - printf()](https://www.runoob.com/cprogramming/c-function-printf.html)。
当您在 Linux 上编译并执行上面的程序时,它会产生下列结果:
~~~
int 存储大小 : 4
~~~
## 浮点类型
下表列出了关于标准浮点类型的存储大小、值范围和精度的细节:
| 类型 | 存储大小 |值范围|精度|
| --- | --- |--- |--- |
| float | 4 字节 |1.2E-38 到 3.4E+38 | 6 位小数 |
| double | 8 字节 |2.3E-308 到 1.7E+308 |15 位小数 |
| long double | 16 字节 |3.4E-4932 到 1.1E+4932 | 19 位小数 |
头文件 float.h 定义了宏,在程序中可以使用这些值和其他有关实数二进制表示的细节。下面的实例将输出浮点类型占用的存储空间以及它的范围值:
```
#include <stdio.h>
#include <float.h>
int main()
{
printf("float 存储最大字节数 : %lu \n", sizeof(float));
printf("float 最小值: %E\n", FLT_MIN );
printf("float 最大值: %E\n", FLT_MAX );
printf("精度值: %d\n", FLT_DIG );
return 0;
}
```
**%E**为以指数形式输出单、双精度实数。
当您在 Linux 上编译并执行上面的程序时,它会产生下列结果:
~~~
float 存储最大字节数 : 4
float 最小值: 1.175494E-38
float 最大值: 3.402823E+38
精度值: 6
~~~
## void 类型
void 类型指定没有可用的值。它通常用于以下三种情况下:
| 序号 | 类型与描述 |
| --- | --- |
| 1 | 函数返回为空C 中有各种函数都不返回值,或者您可以说它们返回空。不返回值的函数的返回类型为空。例如**void exit (int status);** |
| 2 | 函数参数为空 C 中有各种函数不接受任何参数。不带参数的函数可以接受一个 void。例如**int rand(void);** |
| 3 | 指针指向 void 类型为 void \* 的指针代表对象的地址,而不是类型。例如,内存分配函数**void \*malloc( size\_t size );**返回指向 void 的指针,可以转换为任何数据类型。 |
>[danger]注意:如果现在您还是无法完全理解 void 类型,不用太担心,在后续的章节中我们将会详细讲解这些概念。
- 空白目录
- 第一章 c语言简介
- 1 通俗地理解什么是编程语言
- 2 C语言究竟是一门怎样的语言
- 第二章 算法简介&基本语法
- 1 算法简介
- 2 C 程序结构
- 3 C 基本语法
- 第三章 数据类型
- 1 数据类型
- 2 变量
- 3 常量
- 第四章 运算符
- 1 算术运算符
- 2 关系运算符
- 3 逻辑运算符
- 4 位运算符
- 5 赋值运算符
- 6 杂项运算符(其他运算符)
- 7 c语言中的运算符优先级
- 第五章 控制流
- 1 判断语句
- 2 switch语句
- 3 循环语句
- 4 流程控制相关案例
- 第六章 指针
- 1 c语言指针概述
- 2 指针的算术运算
- 3 指针数组
- 4 指向指针的指针
- 5 传递指针给函数
- 6 从函数返回指针
- 第七章 函数
- 1 函数的语法
- 2 作用域规则
- 3 形参与实参
- 第八章 数组
- 1 C语言中的数组
- 2 多维数组
- 3 传递数组给函数
- 4 从函数返回数组
- 第九章 指针
- 1 分钟彻底理解C语言指针的概念
- 2 C语言指针变量的定义和使用
- 3 C语言指针变量的运算(加法、减法和比较运算)
- 4 C语言数组指针(指向数组的指针)
- 5 C语言字符串指针(指向字符串的指针)
- 第十章 结构体
- 第十一章 练习
- 第十二章 文件操作
- 第十三章 文件操作2