工作 3 年的同事不懂 isEmpty 和 isBlank 的区别,我真是醉了。。

工具类乱象

最近在检查代码时,发现有的同事喜欢用 isEmpty,有的同事喜欢用 isBlank,而且大家用的还不是同一个工具包中的,甚至还有自己手写 String 工具类的,天呀,我真是醉了……


你们公司是否也有这样的情况呢?别说没有,我真不信!


说到这个事情,最近还有个工作 3 年的同事问我 isEmpty 和 isBlank 的区别,好吧,今天就展开讲下。


首先,这两个方法用的都是工具类 StringUtils 里面的方法,都是用来判断字符串是否为空的,而这个工具类到处都是,如下图所示,栈长输入 StringUtil,很多类似的工具类就蹦出来了:


工作 3 年的同事不懂 isEmpty 和 isBlank 的区别,我真是醉了。。


像这样类似的 String 工具类存在不同的包中,有 Netty, Apache commons-lang3, Spring 等等,这也是造成程序员不统一工具类的原因,虽然大部分框架都会自己集成,但用的最多的,方法最全的还要属 Apache commons-lang3 工具包。


commons-lang3 是 Apache 下面的一个开源的通用 Java 工具包,除了常用的字符串工具类,还包含数字工具类、时间工具类、反射工具类、线程工具类,等等……


更多请参考《排名前 16 的 Java 工具类》这篇文章。


为什么推荐通用的 commons-lang3?


一方面,commons-lang3 是专业的工具包,功能非常齐全、强大。


另一方面,不一定所有的项目都会用到 Netty、Spring 等框架,它们都是框架集成的,只有一小部分功能,方法并不齐全,所以通用的 commons-lang3 工具包对系统迁移、或者对全公司不同系统之间的共用有帮助,避免差异化引起的系统潜在 bug。


isEmpty 和 isBlank 区别?

说了这么多,isEmpty 和 isBlank 到底有啥区别?


1)isEmpty

判断字符串是否为空字符串,只要有一个任意字符(包括空白字符)就不为空。


来看 isEmpty 的方法源码:

public static boolean isEmpty(CharSequence cs) {
    return cs == null || cs.length() == 0;
}

看见没,这个方法只判断了是为为 null 或者长度为 0。


意味着,如果用户输入 " " 等空白字符,这个方法就不通过了,结果就是不为空了。


如验证输入以下内容:

工作 3 年的同事不懂 isEmpty 和 isBlank 的区别,我真是醉了。。

2、isBlank

判断字符串是否为空字符串,全部空白字符也为空。

来看 isBlank 的方法源码:

public static boolean isBlank(CharSequence cs) {
    int strLen = length(cs);
    if (strLen == 0) {
        return true;
    } else {
        for(int i = 0; i < strLen; ++i) {
            if (!Character.isWhitespace(cs.charAt(i))) {
                return false;
            }
        }

        return true;
    }
}

看见没,第 7 行,只要有一个字符不为空白字符就返回 false,也就是说,如果全部都为空白字符就返回 true,也就是全部空白字符也为空。

如验证输入以下内容:

工作 3 年的同事不懂 isEmpty 和 isBlank 的区别,我真是醉了。。

这时候,如果用户输入 " " 等空白字符,这个方法也返回空了,这也是大部分业务场景下我们期望出现的结果。


isEmpty 和 isBlank 怎么选?

很明显,我们要判断一个字符串为空,绝大部分情况下 "空白字符" 也要为空的,严谨来说肯定要用 isBlank,虽然 isEmpty 也可以,但如果在最前端的接口不被拦截掉,请求到了后端的服务、数据库,就可能会造成压力,甚至是系统异常,这是完全可以避免的。


但万事也没有绝对,如果你的程序可以接受任意字符,包括 "空白字符",那就要选择 isEmpty,isBlank 会拦截所有空白字符,就达不到要求。


所以,这两个工具方法你会用了吗?


与之相对应的一般还有 isNotEmpty 和 isNotBlank,这都是对工具类的封装。


好了,今天的分享就到这了,后续栈长还会继续分享一些工作中常用的开发小技巧,关注公众号Java技术栈第一时间推送,在公众号菜单中还能看栈长整理的历史工具类系列文章。


如果有帮助,点个在看鼓励一下哦!也欢迎分享转发给更多有需要的朋友~


上一篇:Paxos分析之一—Paxos是什么


下一篇:机器学习单挑数学界:最新算法仲裁数列之美(附论文)