1、JShell剧本工具是JDK9的新特征:
什么时刻会用到JShell工具呢;当我们编写代码异常少的时刻,而又不愿意编写类,main方式时;也不愿意去编译和运行,这个时刻就用到JShell工具。

public class HelloWorld{
    public static void main(String[] args){
        System.out.print("Hello, World!");
    }
}

2、若何启动JShell

// 直接启动JShell
C:\Users\Administrator>jshell
jshell> System.out.println("Hello, World!");
Hello, World!

jshell> int a = 10;
a ==> 10

jshell> int b = 20
b ==> 20

jshell> int result = a * b;
result ==> 200

jshell System.out.println("效果是:" + result);
效果是:200
jshell> /exit
再见

2、编译器:
代码库:Demo12Notice.java

,

以太坊高度

www.326681.com采用以太坊区块链高度哈希值作为统计数据,联博以太坊统计数据开源、公平、无任何作弊可能性。联博统计免费提供API接口,支持多语言接入。

,
/*
对于byte/short/char三种类型来说,若是右侧赋值的数值没有跨越局限,
那么javac编译器将会自动隐含地为我们补上一个(byte)(short)(char)。

1. 若是没有跨越左侧的局限,编译器补上强转。
2. 若是右侧跨越了左侧局限,那么直接编译器报错。
*/
public class Demo12Notice {
    public static void main(String[] args) {
        // 右侧确实是一个int数字,然则没有跨越左侧的局限,就是准确的。
        // int --> byte,不是自动类型转换
        byte num1 = /*(byte)*/ 30; // 右侧没有跨越左侧的局限
        System.out.println(num1); // 30

        // byte num2 = 128; // 右侧跨越了左侧的局限

        // int --> char,没有跨越局限
        // 编译器将会自动补上一个隐含的(char)
        char zifu = /*(char)*/ 65;
        System.out.println(zifu); // A
    }
}

代码库:Demo13Notice.java

/*
在给变量举行赋值的时刻,若是右侧的表达式当中全都是常量,没有任何变量,
那么编译器javac将会直接将若干个常量表达式盘算获得效果。
short result = 5 + 8; // 等号右边全都是常量,没有任何变量介入运算
编译之后,获得的.class字节码文件当中相当于【直接就是】:
short result = 13;
右侧的常量效果数值,没有跨越左侧局限,以是准确。

这称为“编译器的常量优化”。

然则注重:一旦表达式当中有变量介入,那么就不能举行这种优化了。
*/
public class Demo13Notice {
    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; // 18    从int装换为short类型可能会发生损失。
    }
}