编译器的常量优化

2021/7/16 23:07:11

本文主要是介绍编译器的常量优化,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

package com.baidu.www.Scanner;
/*
对于byte/short/char三种类型来说,如果右侧赋值的数字没有超过范围,
那么JAVAc编译器将会自动隐含的为我们补上一个(byte)(short)(char).

1.如果没有超过左侧的范围,编译器补上强转。
2.如果右侧超过了左侧范围,那么直接编译器报错。
 */
public class Demo16 {
    public static void main(String[] args){
        //右侧确实是一个int数字,但是没有超过左侧范围,就是正确的。
        //int -->byte,不是自动类型转换
        byte num1 = /*(byte)*/30;// 右侧没有超过左侧范围
        System.out.println(num1);//30

        //int-->char,没有超过范围
        //编译器将会自动补上一个隐含的(char)
        char num2 = /*(char)*/65;
        System.out.println(num2);// A

    }
}
package com.baidu.www.Scanner;
/*
在给变量进行赋值的时候,如果右侧的表达式当中全是常量,没有任何变量
那么编译器javac将会直接将若干个常量表达式计算得到结果。
short result = 5 + 8;// 等号右边全都是常量,没有任何变量参与运算。
编译之后,得到.class字节码文件当中相当于{直接就是}:
short result = 13;
右侧的常量结果数值,没有超过左侧范围,所以正确。

这称为”编译器的常量优化“。
但是注意:一旦表达式变量参与,那么就不能进行这种优化了。

 */

public class Demo17 {
    public static void main(String[] args) {
        short num1 = 10;

        short a = 5;
        short b = 8;
        // short + short--> int + int -->int
        //short result = a + b; 错误写法!左侧需要int

        //右侧不用变量,而是采用常量,而且是两个常量。没有别人
        short result = 5 + 8;
        System.out.println(result);

        //short result2 = 5 + a + 8 ;错误


    }
}


这篇关于编译器的常量优化的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!


扫一扫关注最新编程教程