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 类型,在后续的章节中我们将会详细讲解这些概念。

关于   |   FAQ   |   我们的愿景   |   广告投放   |  博客

  简单教程,简单编程 - IT 入门首选站

Copyright © 2013-2022 简单教程 twle.cn All Rights Reserved.