C 语言是一门强类型的语言,类型决定语言的特性,允许在相同类型进行运算。所以在C语言中有很多数据的类型。
数据类型
在C语言钟我们常说的四大类型分别是
- 基本类型
- 枚举类型
- void类型
- 派生类型
基本类型是算术类型,包括两种类型:整数类型和浮点类型。
枚举类型也是算术类型,被用来定义在程序中只能赋予其一定的离散整数值的变量。
void 类型是类型说明符 void 表明没有可用的值。
派生类型它们包括:指针类型、数组类型、结构类型、共用体类型和函数类型。
那么C语言中有这么多类型它们有什么不同呢?
它表现在一几个方面:
-
类型名称:int、long、double
-
输入输出时的格式化:%d、%ld、%lf
-
所表达的数的范围:char < short < int < float <double
-
内存中所占据的大小:1个字节到16个字节内存中的表达形式:二进制数(补码)、编码
sizeof
在C语言中有一个工具运算符,它可以给出某一个类型或者变量在内存中所占据的字节数
- sizeof(int)
- sizeof(i)
例子:
#include <stdio.h>
int main( )
{
int a;
a=6;
printf( "sizeof(int))=%ld\n",sizeof(int));
printf( "sizeof(a))=%ld\n",sizeof(a));
return 0;
}
结果:
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-wC3927kp-1649861024995)(https://secure2.wostatic.cn/static/paGoBCWevapYNouLYDPDAH/image.png)]](https://i-blog.csdnimg.cn/blog_migrate/bff95d8099a91b88c5adaffa7d4ec2a2.png)
注意:
- 是静态运算符,它的结果在编译时刻就决定了
- 不要在sizeof的括号里做运算,这些运算不会做的
- 当我们使用sizeof的时候根据不同的电脑位数和编译器版本得到的结果可能也不一样
整数类型
一张表了解一下不同的整数类型它们的出巡大小和范围:
| 类型 | 存储大小 | 值范围 |
|---|---|---|
| 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 |
注意:
int类型和long类型的储存大小取决于编译器(CPU)。
浮点类型
一张表了解浮点类型的存储大小、值范围和精度:
| 类型 | 存储大小 | 值范围 | 精度 |
|---|---|---|---|
| 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 位有效位 |
C语言包含多种数据类型,如基本类型、枚举、void和派生类型。基本类型包括整数和浮点数,如int、long、double等,它们有不同的内存占用和数值范围。枚举用于定义离散的整数值。void类型表示无特定值。派生类型包括指针、数组、结构体、共用体和函数。sizeof运算符用于获取类型或变量的内存占用。整数类型如int和long的大小取决于编译器。浮点类型如float、double和long double具有不同的存储大小、值范围和精度。理解这些类型及其差异对于高效编程至关重要。

被折叠的 条评论
为什么被折叠?



