JDK14中的switch

前言

switchJDK12之后,语法得到改善,不过JDK12是预览属性,后面在JDK14转正

switch语法

JDK12之前,switch写法是这样

csharp 复制代码
public class SwitchDemo {

    public static void main(String[] args) {
        int a = 1;
        switch (a) {
            case 1: {
                System.out.println(1);
                break;
            }
            case 2: {
                System.out.println(2);
                break;
            }
            default : {
                System.out.println("aaa");
                break;
            }
        }
    }
}

但是JDK12之后对switch进行改进和预览,可以这么写

arduino 复制代码
public class SwitchDemo {

    public static void main(String[] args) {
        int a = 1;
        int data = switch (a) {
            case 1 -> 1;
            case 2 -> 2;
            default -> throw new IllegalStateException("Unexpected value: " + a);
        };
        System.out.println(data);
    }
}

也可以这么写

csharp 复制代码
public class SwitchDemo {

    public static void main(String[] args) {
        int a = 1;
        switch (a) {
            case 1 -> {
                a = a + 1;
                System.out.println(a);
            }
            case 2 -> {
                a = a + 2;
                System.out.println(2);
            }
            default -> throw new IllegalStateException("Unexpected value: " + a);
        }
        ;
        System.out.println(data);
    }
}

不用加break

总结

switch语法在JDK14之后得到转正,新的 Switch 表达式允许在 switch 块中使用 -> 箭头符号来代替 casebreak 关键字,使代码更加简洁明了

相关推荐
小码哥_常22 分钟前
Spring Boot接口防抖秘籍:告别“手抖”,守护数据一致性
后端
心之语歌38 分钟前
基于注解+拦截器的API动态路由实现方案
java·后端
None32138 分钟前
【NestJs】基于Redlock装饰器分布式锁设计与实现
后端·node.js
初次攀爬者40 分钟前
Kafka + KRaft模式架构基础介绍
后端·kafka
洛森唛1 小时前
Elasticsearch DSL 查询语法大全:从入门到精通
后端·elasticsearch
拳打南山敬老院1 小时前
Context 不是压缩出来的,而是设计出来的
前端·后端·aigc
初次攀爬者2 小时前
Kafka + ZooKeeper架构基础介绍
后端·zookeeper·kafka
LucianaiB2 小时前
Openclaw 安装使用保姆级教程(最新版)
后端
华仔啊2 小时前
Stream 代码越写越难看?JDFrame 让 Java 逻辑回归优雅
java·后端
ray_liang2 小时前
用六边形架构与整洁架构对比是伪命题?
java·架构