1、我们先说明下一个无符号整型和有符号整型的区别.写个程序来看看。
2、我们直接使用库来写,他在里面定义了signed和unsigned的最大值和最小值。unsigned只有最大值,最小值就是0.
3、从图中可以看出signed int 的表示范围为:-2147483648 ~ 2147483647 (最高位做符号位)。unsigned int 的表示范围为:0 ~ 4294967295 (不保留符号位)
4、那么为什么float会没有无符号呢?我们可以从上面看出,无符号和有符号的区别,整型是采用二进制的。而浮点数却是按照 整数部分,小数部分,指数部分存放的。运算也是分开来运算的。所以unsigned无法作用于float,所以定义无符号的浮点型会出错。
5、这样就可以知道,符号是占用了一个比特位的。所以,一般来说,同类型的signed能够存储的数的绝对值大小是要小于undigned的。
6、在C语言中,计算的时候会类型提升,如果降低会警告,或者无符号类型的值给比这个类型小的有符号类型的值的时候,编译的时候就会警告了。
7、当然,这并不是错误,只是告诉你把大的值给小的值可能会数据丢失。所以最好避免这样的错误。顺便推荐下在windows使用gcc的安装工具是MinGW。