本帖最后由 STM32W 于 2010-11-13 08:12 编辑
原因很简单:
A=B
B的值不会因为A得类型而改变。
A=B*C
是先计算B*C的结果,再赋值给A
B*C的结果不会因为A得类型而改变。
回到正题:
addr = 10*4096;(2)
先不管addr是什么类型,先计算10*4096的值,10*4096运算的结果本身与addr是什么类型无关。
首先要搞清楚,10,4960是什么类型。
根据C语言标准,字面值10进制常数,如果在int范围,则类型是int.
10*4960
相当于((int)10)*((int)4096)=-24576
addr = 10*4096;
相当于addr = -24576
结果:addr的值为0xFFFFA000
再举个例子:
float f;
f=1/10;
f 结果是0.0,而不是0.1。
因为是先计算1/10,再赋值给f,
而不是先转换成浮点,再计算。
1/10本身的运算结果与f的类型无关。
改为addr=addr*7为什么结果会对呢?
先看表达式addr*7,
addr的类型是long,7的类型是int.
按照C语言运算规则,long与int运算,int自动提升至long。
addr*7相当于
((long)addr)*((long)7)
结果是对的,没有溢出。
谨记:
形如
A=表达式
是先计算表达式的值,再把值赋值给A。
表达式运算的结果是按照表达式自己的运算规则运算,
不要想当然,表达式会用A的类型进行计算。
|