在 C 语言中,数据类型指的是用于声明不同类型的变量或函数的一个广泛的系统。变量的类型决定了变量存储占用的空间,以及如何解释存储的位模式。
C 中的类型可分为以下几种:
类型 | 表述 |
基本类型 | 它们是算术类型,包括两种类型:整数类型和浮点类型。 |
枚举类型 | 它们也是算术类型,被用来定义在程序中只能赋予其一定的离散整数值的变量。 |
void类型 | 类型说明符 void 表明没有可用的值。 |
派生类型 | 它们包括:指针类型、数组类型、结构类型、共用体类型和函数类型。 |
数组类型和结构类型统称为聚合类型。函数的类型指的是函数返回值的类型。
整数类型
下面会通过表格列出标准整数类型各个不同种类的存储大小和值的范围:
类型 | 存储大小(字节) | 值的范围 |
unsigned char | 1 | 0 -- 255 |
char | 1 | -128 -- 127 |
signed char | 1 | -128 -- 127 |
unsigned int | 2或4 | 0 -- 65,535 或 0 -- 4,294,967,295 |
int | 2或4 | -32,768 -- 32,767 或 -2,147,483,648 -- 2,147,483,647 |
unsigned short | 2 | 0 -- 65,535 |
short | 2 | -32,768 -- 32,767 |
unsigned long | 4 | 0 -- 4,294,967,295 |
long | 4 | -2,147,483,648 -- 2,147,483,647 |
各种类型的存储大小和系统的位数是有关系的,32位系统和64位系统下是不一样的。
void类型
void类型通常用于以下三种情况:
类型 | 描述 |
函数返回为空 | C 中有各种函数都不返回值,或者您可以说它们返回空。不返回值的函数的返回类型为空。 |
函数参数为空 | C 中有各种函数不接受任何参数。不带参数的函数可以接受一个 void。 |
指针指向void | 类型为 void * 的指针代表对象的地址,而不是类型。返回指向 void 的指针,可以转换为任何数据类型。 |
浮点类型
浮点类型通俗来说就是带小数的数,下面列出了标准浮点类型的存储大小、精度和范围
类型 | 存储大小(字节) | 精度 | 范围 |
float | 4 | 6 位有效位 | 1.2E-38 到 3.4E+38 |
double | 8 | 15 位有效位 | 2.3E-308 到 1.7E+308 |
long double | 16 | 19 位有效位 | 3.4E-4932 到 1.1E+4932 |