C语言数据类型还有哪些搞不明的
作者:菊花花生油456
数据类型的介绍
在C语言中有丰富的数据类型描述现实中的数据
C语言将我们平时日常生活中的数据分成三种:整形类型 字符类型 浮点类型
- 整形类型
整形类型从名字可以联想到什么?
整形
对就是这样
在C语言中使用int表示整形类型,(源于整形的英文单词integer)
//短整型 short [int] [signed] short [int] unsigned short [int] //整形 int [signed] int unsigned int //长整型 long [int] [signed] long [int] unsigned long [int] //更长的整形 //c99中引入 long long [int] [signed] long long [int] unsigned long long [int]
- 字符类型
字符包括字母,文字,符号等等都是字符
在C语言中用char表示(源于英文字母character)
char [signed] char unsigned char
- 浮点类型
小数点的浮动浮点类型
float double long double
- 布尔类型
区别于其他类型,是用来判断真假的一种类型
C语言中原来并没有为布尔值单独设置一个类型,而是使用0表示假,非零表示真
在C99中引用布尔类型:true或者false
#define bool _Bool #define false 0 //假 #define true 1 //真
代码演示
_Bool flag = true;
if (flag)
printf ("i like C\n"0);
这时候有人有疑问了这个int ,char ,double我都知道了,但是这个signed,unsigned还有long是什么意思,咋突然就出现了
首先我们来说一下long
这时候大家就要知道一个东西,每种数据类型都有自己的长度,接下来我们详细说一下
各种数据类型的长度
每一种数据类型都有自己的长度,占用的内存空间不同,使用合适的类型长度能够节省内存空间,加大开发效率
sizeof操作符sizeof是一个关键字,也可以是操作符,是用来专门计算类型长度的,单位是字节
接下来我们来看一下这些数据类型的具体长度
#include <stdio.h>
int main()
{
printf ("%zu\n",sizeof(_Bool));
printf ("%zu\n",sizeof(char));
printf ("%zu\n",sizeof(short));
printf ("%zu\n",sizeof(int));
printf ("%zu\n",sizeof(long));
printf ("%zu\n",sizeof(long long));
printf ("%zu\n",sizeof(float));
printf ("%zu\n",sizeof(double));
printf ("%zu\n",sizeof(long double));在VS2022 X64配置下的运行结果为:
1
1
2
4
4
8
4
8
8
另外还有一个表示长度的单位比字节更小,就是比特
1字节=8比特
由此我们可以的得到每个数据类型的长的度,这时候有的人可能会发现自己得出的结果不一样
这是因为C语言规定sizof(long)>=sizof(int)所以有的配置环境下的结果是8sizeof(long double)>=sizeof(double)也是这样了,在有些配置下的的结果是16
sizeof的操作符的操作数可以是类型,也可以是变量或者表达式,后面跟的是表达式的时候,括号可以去掉,
sizeof(类型) sizeof 表达式
sizeof后面的表达式不真实参与运算的,根据表达式的类型来得出大小
#include <stdio.h>
int mian()
{
short s = 12;
int b = 10;
prinrf("%zu\n",sizeof(s = b + 1 ));
printf("s = %d\n",s);
return 0;
}
运行结果为
2
s = 12
为什么呢?
首先无论等号后面的数字有多么大他都要放在这个short的这个空间里面,这个空间的字节大小是2,1的数据类型是int,b的类型也是int表达式不参与运算,等号右边的类型是int,但int这个类型的长度是4不够存放就直接截去,所以是2
而12由于sizeof后面的表达式不参与计算所以依然是12
signed 和 unsigned
C语言使用signed和unsigned关键字修饰字符型和整型类型的signed表示类型整形带有正负号和零unsigned表示整形正整数和零
对于int类型,默认是带有正负号的也即是说signed int等同于sgned int
signed int a; //等同于int a;
想要只表示负数就要加unsigned声明变量
unsigned int a;
声明变量的好处是同样长度的内存能够表示的最大整数类型扩大一倍
比如,16位的signed short int 的取值范围是:-32768~32767,最大是32767;而unsigned short int的取值范围是:0~65535,最大值增加到了65535。32位的siggned int的取值范围可以参考limits.h中给的相关定义。
下面是在VS2022环境中,limits.h中的相关定义
#define SHRT_MIN (-32768) //有符号16位整型的最小值 #define SHRT_MAX 32767 //有符号16位整型的最大值 #define USHRT_MAX 0xfff //无符号16位整型的最大值 #define INT_MIN (-2147483647 -1) //有符号整型的最小值 #define INT_MAX 2147483647 ///有符号整型的最大值
unsigned int里面的int可以省略,所以也可以写成
unsigned a;
字符类型char也有signed和unsigned
signed char c;//范围为-128到127 unsigned char c;//范围为0到255
注意,C语言规定char类型默认是否包括符号是由当前系统决定的
所以char不等同与signed char,可能是signed char也可能是unsigned char
这一点区别于int
到此这篇关于C语言数据类型还在搞不明白?的文章就介绍到这了,更多相关C语言数据类型内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
