1. signed和unsigned
c语言是使用signed
和unsigned
关键字来修饰字符型和整型类型的。
signed
关键字,表示一个类型带有正负号,包含正负值;
unsigned
关键字,表示该类型不带有正负号,只能表示零和正整数。
对于int类型,默认是带有正负号的,也就是说int
就是signed int
的缩写,两种都可以用。
1 signed int a;
2 int a;//哪个简单用哪个,正负值都可以使用
int
类型也可以不带正负号,只表示非负整数,这就需要使用unsigned
来声明。
1 unsigned int a;
整数变量声明为 unsigned
的好处是,同样⻓度的内存能够表⽰的最⼤整数值,增⼤了⼀倍。
⽐如,16位的 signed short int
的取值范围是:-32768~32767,最⼤是32767;⽽unsigned short int
的取值范围是:0~65535,最⼤值增⼤到了65535。32位的 signed int
的取值范围可以参看 limits.h 中给出的定义。
下⾯的定义是VS2022环境中,limits.h中的相关定义。
1 #define SHRT_MIN (-32768) //有符号16位整型的最小值
2 #define SHRT_MAX (32768) //有符号16位整型的最大值
3 #define USHRT_MAX (0xffff) //无符号16位整型的最大值
4 #define INI_MIN (-214783647,-1) //有符号整型的最小值
5 #define INI_MIN (214783647) //有符号整型的最大值
unsigned int
⾥⾯的 int
可以省略,所以上⾯的变量声明也可以写成下⾯这样。
1 unsigned a;
字符类型 char
也可以设置 signed
和 unsigned
。
1 signed char c; // 范围为 -128 到 127
2 unsigned char c; // 范围为 0 到 255
注意,C语⾔规定 char
类型默认是否带有正负号,由当前系统决定。
这就是说, char
不等同于 signed char
,它有可能是 signed char
,也有可能是unsigned char
。
这⼀点与 int
不同, int
就是等同于 signed int
。
2.数据类型的取值范围
上述数据类型很多,尤其数整型类型就有short、int、long、long long四种,为什么呢?
其实每⼀种数据类型都有⾃⼰的取值范围,也就是存储的数值的最⼤值和最⼩值的区间,有了丰富的类 型,我们就可以在适当的场景下去选择适合的类型。如果要查看当前系统上不同数据类型的极限值:
limits.h
⽂件中说明了整型类型的取值范围。
float.h
这个头⽂件中说明浮点型类型的取值范围。
为了代码的可移植性,需要知道某种整数类型的极限值时,应该尽量使⽤这些常量。
• SCHAR_MIN
, SCHAR_MAX
:signed char的最⼩值和最⼤值。
•SHRT_MIN
, SHRT_MAX
:short的最⼩值和最⼤值。
• INT_MIN
, INT_MAX
:int的最⼩值和最⼤值。
• LONG_MIN
, LONG_MAX
:long的最⼩值和最⼤值。
• LLONG_MIN
,LLONG_MAX
:long long的最⼩值和最⼤值。
• UCHAR_MAX
:unsigned char的最⼤值。
• USHRT_MAX
:unsigned short的最⼤值。
• UINT_MAX
:unsigned int的最⼤值。
• ULONG_MAX
:unsigned long的最⼤值。
• ULLONG_MAX
:unsigned long long的最⼤值。
#include <stdio.h>
int main()
{
printf("%zd\n",sizeof(char)); //sizeof 是一个操作符,计算的是类型创建的变量所占
printf("%zd\n",sizeof(short)); 内存的大小,单位是字节
printf("%zd\n",sizeof(int));
printf("%zd\n", sizeof(long));
printf("%zd\n", sizeof(long long));
printf("%zd\n", sizeof(float));
printf("%zd\n", sizeof(double));
printf("%zd\n", sizeof(short int));
printf("%zd\n", sizeof(long int));
printf("%zd\n", sizeof(unsigned char));
printf("%zd\n", sizeof(unsigned short));
printf("%zd\n", sizeof(unsigned int));
printf("%zd\n", sizeof(unsigned long));
printf("%zd\n", sizeof(unsigned long long));
int Add(int x, int y)
{
return x+y;
}
结果从上到下依次打印出来。
以上均为个人的一些见解,本人目前还是初学者,如果有误,欢迎大家指正!