switch多值匹配骚操作,带你涨姿势!

简介: 我们都知道 switch 用来走流程分支,大多情况下用来匹配单个值,如下面的例子所示:
/**
 * @from 微信公众号:Java技术栈
 * @author 栈长
 */
private static void test(int value) {
    switch (value) {
        case 1:
            System.out.println("1");
            break;
        case 2:
            System.out.println("1");
            break;
        case 3:
            System.out.println("1");
            break;
        case 4:
            System.out.println("1");
            break;
        case 5:
            System.out.println("1");
            break;
        case 6:
            System.out.println("0");
            break;
        case 7:
            System.out.println("0");
            break;
        default:
            System.out.println("-1");
    }
}

相关阅读:switch case 支持的 6 种数据类型。


大概的意思就是,周一到周五输出:1,周六到周日输出:0,默认输出-1。


这样写,很多重复的逻辑,冗余了。


也许这个例子不是很合适,用 if/ else 更恰当,但这只是个例子,实际开发中肯定会有某几个 case 匹配同一段逻辑的情况。


那么,如何让多个 case 匹配同一段逻辑呢?


如下面例子所示:

/**
 * @from 微信公众号:Java技术栈
 * @author 栈长
 */
private static void test(int value) {
    switch (value) {
        case 1: case 2: case 3: case 4: case 5:
            System.out.println("1");
            break;
        case 6: case 7:
            System.out.println("0");
            break;
        default:
            System.out.println("-1");
    }
}

把相同逻辑的 case 放一起,最后一个 case 写逻辑就行了。

格式化后就是这样了:

1./**
 * @from 微信公众号:Java技术栈
 * @author 栈长
 */
private static void test(int value) {
    switch (value) {
        case 1: 
        case 2: 
        case 3: 
        case 4: 
        case 5:
            System.out.println("1");
            break;
        case 6: 
        case 7:
            System.out.println("0");
            break;
        default:
            System.out.println("-1");
    }
}



其实这不是最合适的最好的写法,在 Java 12 中还可以更骚。


在 Java 12 中可以用逗号来分开多个值,还能用 lambda 表达式,甚至还能省略 break,使用 switch 更方便,具体看这篇文章:Java 12 骚操作, switch居然还能这样玩,或者关注微信公众号:Java技术栈,在后台回复 "新特性" 获取这篇文章。

目录
相关文章
|
关系型数据库 MySQL 索引
B+树索引使用(7)匹配列前缀,匹配值范围(十九)
B+树索引使用(7)匹配列前缀,匹配值范围(十九)
|
Java
高效实现区间条件过滤:Java字符串转换为条件语句
高效实现区间条件过滤:Java字符串转换为条件语句
108 0
|
存储 Java 网络安全
用正则表达式匹配3的任意倍数
正则表达式能匹配3的任意倍数?(注意是任意倍数) ,我曾经也很震惊,但确实可以。我5年多前练习正则表达式,在Regex Golf这个正则表达式测试网站上发现了这个题,当时完全没有任何头绪,于是我在知乎提问正则表达式如何匹配 3 的倍数 ,但是得到了好多知乎大佬的关注,也上了当天的热榜。 排名第一的答主已经给出了答案和思路,但这么多年来我一直都没看懂,最近学习编译原理,看到正则表达式和DFA,于是仔细研究了一下这个问题,并将问题扩展至匹配N的倍数,最后给出通用解法和代码。
52 0
|
9月前
|
C#
C#动态查询:巧用Expression组合多条件表达式
在C#中,利用`Expression`类和`AndAlso`、`OrElse`方法,可以组合两个`Expression<Func<T, bool>>`以实现动态多条件查询。该方法通过构建表达式树,方便地构建复杂查询。示例代码展示了如何创建表达式树,分别检查年龄大于等于18和姓名为"John"的条件,并使用`AndAlso`组合这两个条件,最终编译为可执行的委托进行测试。
382 1
|
9月前
|
存储 程序员 编译器
【新手解答5】深入探索 C 语言:宏中的文本、标识符和字符串 + 递归运算、条件语句、循环 + `switch-case` 与多项条件和枚举的差别
【新手解答5】深入探索 C 语言:宏中的文本、标识符和字符串 + 递归运算、条件语句、循环 + `switch-case` 与多项条件和枚举的差别
98 0
|
存储 算法 容器
Leetcode 76最小覆盖子串&77组合&78子集
给你一个字符串 s 、一个字符串 t 。返回 s 中涵盖 t 所有字符的最小子串。如果 s 中不存在涵盖 t 所有字符的子串,则返回空字符串 “” 。
131 0
Leetcode 76最小覆盖子串&77组合&78子集
7-16 求符合给定条件的整数集 (15 分)
7-16 求符合给定条件的整数集 (15 分)
115 0

热门文章

最新文章