C语言中的数值

##数值的类型

C语言中的数值类型有

整型:short int,int, long int
浮点型:float, double
字符型:char

其中又分为有符号数signed和无符号数unsigned。
其实数值在内存中存储时只是一串二进制串,没有正负之分,所谓的正负是如何去解释这个二进制串。例如:

1
2
unsigned int a = -1;
printf("%u %d\n", a, a);

我们指定%u和%d两种方式输出,得到结果:4294967295 -1
我们定义变量的类型是给编译器看的,而变量本身只是内存空间,你想让它后来解释成什么类型就解释成什么类型。

##C语言中的数值转换

###隐式转换
C语言在以下四种情况下进行隐式转换:

1、算术运算式中,低类型能够转换为高类型。
2、赋值表达式中,右边表达式的值自动隐式转换为左边变量的类型,并赋值给他。
3、函数调用中参数传递时,系统隐式地将实参转换为形参的类型后,赋给形参。
4、函数有返回值时,系统将隐式地将返回表达式类型转换为返回值类型,赋值给调用函数。

###算数运算的隐式转换
算数运算的类型转换规则:

1、字符必须先转换为整数(C语言规定字符类型数据和整型数据之间可以通用) 。
2、short型转换为int型(同属于整型) 。
3、float型数据在运算时一律转换为双精度(double)型,以提高运算精度(同属于实型) 。

当不同类型的数据进行操作时,应当首先将其转换成相同的数据类型,然后进行操作,转换规则是由低级向高级转换。

char,short->int->unsigned->long->double<-float

当表达式中存在有符号类型和无符号类型时所有的操作数都自动转换为无符号类型。

1
2
unsigned int a = 20;
int b = -20;

比较a和b的大小会发现a < b,因为在C语言操作中,如果遇到无符号数与有符号数之间的
操作,编译器会自动转化为无符号数来进行处理。

对于浮点数来说,浮点数(float,double)实际上都是有符号数,unsigned 和signed前缀不能加在float和double之上,当然就不存在有符号数根无符号数之间转化的问题了。

学习这些知识为了下一篇文章介绍关于cpython源码中判断整数溢出的操作做准备。

参考链接
(http://blog.csdn.net/zhuimengzh/article/details/6728492)