C 语言数据类型
前面章节中我们已经学习了 C 语言的基本语法,了解了构成 C 语言程序的各种元素。我们也见到过了 int age;
这种语句。现在,我们就来学习下 C 语言中的数据类型。
int age;
这段代码中的 int
就是一种数据类型。
在 C 语言中,数据类型指的是用于声明不同类型的变量或函数的一个广泛的系统。
变量的类型决定了变量存储占用的空间,以及如何解释存储的位模式
C 语言中的数据类型可分为以下 4 类
类型 | 描述 |
---|---|
基本类型 | 算术类型,包括两种类型:整数类型和浮点类型 |
枚举类型 | 算术类型,被用来定义在程序中只能赋予其一定的离散整数值的变量 |
void 类型 | 类型说明符void表明没有可用的值 |
派生类型 | 它们包括:指针类型、数组类型、结构类型、共用体类型和函数类型 |
数组类型和结构类型统称为聚合类型。
函数的类型指的是函数返回值的类型。
在本章节接下来的部分我们将介绍基本类型,其他几种类型会在后边几个章节中进行讲解。
整数类型
下表是整数类型的存储大小和值范围的细节
类型 | 存储空间大小 | 值范围 |
---|---|---|
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 |
注意,各种类型的存储大小与系统 CPU 位数有关,但目前通用的以64位 CPU 为主。
以下列出了32位系统与64位系统的存储大小的差别(windows 相同):
可以使用 sizeof
运算符得到某个类型或某个变量在特定平台上的准确大小。
表达式 sizeof(type)
可以对象或类型的存储字节大小。
下面的实例演示了获取 int 类型的大小:
范例
/** * file: sizeof.c * author: 简单教程(www.twle.cn) */ #include <stdio.h> #include <limits.h> int main() { printf("int 存储大小 : %lu \n", sizeof(int)); printf("long 存储大小 : %lu \n", sizeof(long)); return 0; }
在 Centos 7.x 系统上编译运行上面的程序,输出结果如下:
int 存储大小 : 4 long 存储大小 : 8
浮点类型
下表是标准浮点类型的存储大小、值范围和精度的细节:
类型 | 存储大小 | 值范围 | 精度 |
---|---|---|---|
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
头文件定义了宏,在程序中可以使用这些值和其他有关实数二进制表示的细节。
下面的范例将输出浮点类型占用的存储空间以及它的范围值:
范例
/** * file: sizeof.c * author: 简单教程(www.twle.cn) */ #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 ); printf("\n"); printf("double 存储最大字节数 : %lu \n", sizeof(double)); printf("double 最小值: %E\n", DBL_MIN ); printf("double 最大值: %E\n", DBL_MAX ); printf("精度值: %d\n", DBL_DIG ); return 0; }
在 Centos 7.x 系统上编译运行上面的程序,输出结果如下:
float 存储最大字节数 : 4 float 最小值: 1.175494E-38 float 最大值: 3.402823E+38 精度值: 6 double 存储最大字节数 : 8 double 最小值: 2.225074E-308 double 最大值: 1.797693E+308 精度值: 15
void 类型
void 类型指定没有可用的值。
void 通常用于以下三种情况
类型 | 描述 |
---|---|
函数返回为空 | C 中有各种函数都不返回值, 或者您可以说它们返回空 不返回值的函数的返回类型为空。例如 void exit (int status); |
函数参数为空 | C 中有各种函数不接受任何参数。不带参数的函数可以接受一个 void。 例如 int rand(void); |
指针指向 void 类型 | void * 的指针代表对象的地址,而不是类型 例如,内存分配函数 void *malloc( size_t size ); 返回指向 void 的指针void *指针可以转换为任何数据类型。 |
不用太担心现在您还是无法完全理解 void 类型,在后续的章节中我们将会详细讲解这些概念。