自动类型提升

在做stm32编程优化float浮点型运算时考虑到了自动类型提升。。当一个表达式中有浮点型数据时整个表达式会提升为浮点型进行运算,大大增加了运算时间。。

以下部分为复制的相关内容。。。。

 

面试过java程序员的或多或少对这个题目有点面熟:

short s1 = 1; s1 = s1 + 1;有什么错? short s1 = 1; s1 += 1;有什么错?

答案是:前者错,后者对。why?  且看下面分解:

java类型计算中,除了强制类型转换,还有各不很面熟的自动类型提升

java在表达式中,对中间值的精确要求有时可能会超过任何一个操作数的范围。例如,考虑下面的表达式: byte a = 40; byte b = 50; byte c = 100; int d = a * b / c; 中间项结果a*b 很容易超过它的任何一个byte 型操作数的范围。为处理这种问题,当分析表达式时,Java自动提升各个byte 型或short型的操作数到int 型。这个过程是java自动进行的,所以可要留意了。

现在我们来分析short s1 = 1; s1 = s1 + 1;为什么错

根据自动类型提升,我们知道,s1 (short型)+ 1(int型),结果为(int),将int赋值给short,会损失精度,当然不可以了。

下面记住自动类型提升的一些规则

One.     所有的byte型和short型的值被提升到int型.

Two.   如果一个操作数是long型,整个表达式将被提升到long型

Three. 如果一个操作数是float型,整个表达式将被提升到float型

Four.   如果有一个操作数是double型,计算结果就是double型

Please learn it by heart,it is not bad!

 
 
JAVA数据类型结构
 1>基本数据类型
        1.1>数值型:
                  1.1.1>整数类型(byte,short,int,long)
                  1.1.2>浮点类型(float,double)
        1.2>字符型(char)
        1.3>布尔型(boolean)

 2>引用数据类型
        2.1>类(class)
        2.2>接口(interface)
        2.3>数组引用

基本类型所占空间:
        byte                        8bit/1byte
        char                        16bit/2byte
        short                      16bit/2byte
        int                          32bit/4byte
        long                        64bit/8byte

        float                      32bit/4byte
        double                    64bit/8byte

1.自动类型转换
      需要同时满足两个条件:
              1>两种类型是彼此兼容的
              2> 转换的目标类型的范围一定要大于 转换的源类型
      即,宗旨是不能出现数据内存单元的截短,而只能扩大
      例:
              byte b=3;
              int i=b;              //编译正常
              int i1=3;
              byte b1=i1;        //编译出错
2.强制类型转换
      当两种类型不兼容 或 转换目标类型范围小于 转换的源类型.即不满足自动类型转换的条件
      格式:  目标类型变量=(目标类型)源类型变量/常量
              int i1=3;
              byte b1=(int)i1;  //编译不会出错
      注意:在强制类型转换中目标类型和源类型变量的类型始终没有发生改变.


3.表达式中的数据类型自动提升
Java定义了若干适用于表达式的类型提升规则

第一、byte,char,short→int;
第二、如果有一个操作数是long,计算结果为long型;
第三、如果有一个操作数是float,计算结果为float型;
第四、如果有一个操作数是double,计算结果为double型.

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值