C语言数据运算中格式问题注意
来源:互联网 发布:淘宝靠谱韩代 编辑:程序博客网 时间:2024/04/19 12:50
A=B
B的值不会因为A得类型而改变。
A=B*C
是先计算B*C的结果,再赋值给A
B*C的结果不会因为A得类型而改变。
addr = 10*4096;
先不管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)
结果是对的,没有溢出。
B的值不会因为A得类型而改变。
A=B*C
是先计算B*C的结果,再赋值给A
B*C的结果不会因为A得类型而改变。
addr = 10*4096;
先不管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)
结果是对的,没有溢出。
- C语言数据运算中格式问题注意
- C语言自增、自减运算符使用中应注意的问题 王红
- c语言数据运算超范围要注意
- c语言中int与float数据运算时,数据转换问题
- C语言注意问题
- C语言中格式转换问题
- C语言---格式问题
- C语言中内存动态分配应注意的问题
- C语言开发中应该注意的一些问题
- C语言 数组注意问题
- C语言 数组注意问题
- 数据传输中常用的数据转换格式C语言实现
- c语言中注意细节
- C语言中整型运算取Ceiling问题
- C 语言中有关常见的运算符问题
- C语言中整型运算取Ceiling问题
- c语言中,逗号运算符的问题
- C语言中运算符的优先级问题
- 开发Chrome入门【一】
- 在生产环境中使用 php 性能测试工具 xhprof
- vc++类型转换
- hbase表结构设计研究(不断更新)
- git 使用详解(4)-- 初体验
- C语言数据运算中格式问题注意
- 面向对象的进阶类的继承
- HashMap遍历的两种方式
- Java 静态方法中如何操作成员变量。
- JUnit 反模式
- JAVA菜鸟(十九)JSP
- 移动支付总额到2015年超9000亿美金
- 通过jQuery遍历div里面的checkbox,实现全选的功能
- Spring MVC过滤器-字符集过滤器(CharacterEncodingFilter)