目录
[3.void 类型](#3.void 类型)
在 C 语言中,数据类型指的是用于声明不同类型的变量或函数的一个广泛的系统。变量的类型决定了变量存储占用的空间,以及如何解释存储的位模式。
C语言的数据类型系统主要分为基本类型、枚举类型、void类型和派生类型四大类。
1.基本类型
**字符型:**用于存储单个字符,占用1字节。
char:可表示字符或小范围整数。
** 整型:**用于存储整数,包括有符号和无符号两种形式。
int:最常见的整型,通常占用4字节。
short:短整型,通常占用2字节。
long:长整型,大小通常为4或8字节,取决于系统和编译器。
long long:超长整型(C99标准),通常占用8字节。

注意,各种类型的存储大小与系统位数有关,但目前通用的以64位系统为主。
**浮点型:**用于存储小数或进行科学计算。
float:单精度浮点型,通常占用4字节,提供约6-7位有效数字。
double:双精度浮点型,通常占用8字节,提供约15-16位有效数字。
long double:扩展精度浮点型,精度和大小因编译器和系统而异。

注:各种类型的存储大小与系统位数有关
**布尔型:**用于表示逻辑值真(true)或假(false)。C99标准引入了_Bool类型,通常占用1字节,取值为0或1;使用bool、true和false需包含<stdbool.h>头文件。
2.枚举类型 (enum)
枚举类型用于定义一组具名的整数常量,增强代码的可读性。
3.void 类型
void类型表示"无类型"。它主要有两种用途:
- 用于指定函数不返回任何值。。
- 用于声明通用指针(void*),该指针可以指向任何类型的数据,但在使用前需要进行类型转换。
4.查看数据类型的存储大小
使用表达式 sizeof(type) 得到对象或类型的存储字节大小。
cpp
#include <stdio.h>
int main()
{
printf("int 存储大小 : %lu \n", sizeof(int)); //%lu 为 32 位无符号整数
printf("char存储大小 : %lu \n", sizeof(char));
printf("short存储大小 : %lu \n", sizeof(short));
return 0;
}

cpp
#include <stdio.h>
#include <float.h> //头文件 float.h 定义了宏
int main()
{
printf("float 存储最大字节数 : %lu \n", sizeof(float));
printf("float 最小值: %E\n", FLT_MIN ); //%E 为以指数形式输出单、双精度实数
printf("float 最大值: %E\n", FLT_MAX );
printf("精度值: %d\n", FLT_DIG );
return 0;
}

5.类型转换
类型转换是将一个数据类型的值转换为另一种数据类型的值。
C 语言中有两种类型转换:
**隐式类型转换:**隐式类型转换是在表达式中自动发生的,无需进行任何明确的指令或函数调用。它通常是将一种较小的类型自动转换为较大的类型,例如,将int类型转换为long类型或float类型转换为double类型。隐式类型转换也可能会导致数据精度丢失或数据截断。
**显式类型转换:**显式类型转换需要使用强制类型转换运算符(type casting operator),它可以将一个数据类型的值强制转换为另一种数据类型的值。强制类型转换可以使程序员在必要时对数据类型进行更精确的控制,但也可能会导致数据丢失或截断。
(1)隐式类型转换:
cpp
#include <stdio.h>
int main()
{
int a=20;
float b=1.2;
double c=a+b;
printf("c的值为%0.5f\n",c);
printf("c的大小为%lu \n",sizeof(c));
return 0;
}

(2)显式类型转换实例:
cpp
#include <stdio.h>
int main()
{
float a = 2.14159;
int b = (int)a; // 显式将double类型转换为int类型
printf("b的值为%d\n",b);
return 0;
}
