Java-无敌空处理,保证你没见过(独此一家,比Optional好用100倍)

这篇具有很好参考价值的文章主要介绍了Java-无敌空处理,保证你没见过(独此一家,比Optional好用100倍)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

为什么要自己写一套判空的呢?

目前java中判空的手段有3种

  1. if
  2. Optional
  3. 三元
  4. 第三方封装工具(基于上3种手段封装的工具)

假设我有一个对象: a-》b-》c 这样一个嵌套关系, 现在我想取出c中的数据那么正常代码如下:

if(a!=null &&a.getB()!=null&&a.getB().getC()!=null{

}else{

}

以上代码有3个问题

  1. 一旦中间有一个是空不能有效的知道是谁, 排查的时候需要写大量的日志
  2. 如果我想在其中一个不为空的时候做些处理然后在继续,那么上面代码就无法满足了,就需要更加复杂的条件拆分了。
  3. 美观问题,一旦大量的if出现在代码中将会导致代码非常臃肿难以阅读

高级的东西往往是朴实的, 啥也不说了直接上代码

package com.huanmin.test.utils_common.base;


import com.huanmin.test.entity.RoleEntity;
import com.huanmin.test.entity.UserEntity;
import com.utils.common.base.Null;
import org.junit.Test;

public class ObjNullTest {


    @Test
    public void test1_ok() {
        UserEntity userEntity = new UserEntity();
        userEntity.setId(1);
        userEntity.setName("huanmin");
        RoleEntity roleEntity = new RoleEntity();
        roleEntity.setRoleName("1234");
        userEntity.setRoleData(roleEntity);

        boolean b = Null.of(userEntity).of(UserEntity::getRoleData).of(RoleEntity::getRoleName).is();
        System.out.println(b);
        String s = Null.of(userEntity).of(UserEntity::getRoleData).of(RoleEntity::getRoleName).get();
        System.out.println(s);
        Null.of(userEntity).of(UserEntity::getRoleData).of(RoleEntity::getRoleName).is( System.out::println);

        Null.of(userEntity).of(UserEntity::getRoleData).of(RoleEntity::getRoleName).isOr(
                System.out::println,
                ()-> System.out.println("isOr")
        );
        String s2 = Null.of(userEntity).of(UserEntity::getRoleData).of(RoleEntity::getRoleName).orThrow(() -> new RuntimeException("orThrow"));
        System.out.println(s2);

        String s1 = Null.of(userEntity).of(UserEntity::getRoleData).of(RoleEntity::getRoleName).orElse("orElse");
        System.out.println(s1);

        String empty = Null.of(userEntity).of(UserEntity::getRoleData).of(RoleEntity::getRoleName).isEmpty();
        System.out.println(empty);

        Integer convert = Null.of(userEntity).of(UserEntity::getRoleData).of(RoleEntity::getRoleName).convert(Integer::parseInt);
        System.out.println(convert);

        Null.of(userEntity).of(UserEntity::getRoleData).of(RoleEntity::getRoleName).stream().forEach(System.out::println);
    }

    //no判断主要用来进行强制中断程序继续执行, 因为在有些场景,下文数据会对上文的数据有着强制的依赖关系,所以需要强制中断,保证数据的完整性
    @Test
    public void test1_error() {
        UserEntity userEntity = new UserEntity();
        userEntity.setId(1);
        userEntity.setName("huanmin");
        RoleEntity roleEntity = new RoleEntity();
        userEntity.setRoleData(roleEntity);

        boolean b = Null.no(userEntity).of(UserEntity::getRoleData).of(RoleEntity::getRoleName).is();

        Null.no(userEntity).no(UserEntity::getRoleData).of(RoleEntity::getRoleName).is( System.out::println);

        Null.no(userEntity).no(UserEntity::getRoleData).no(RoleEntity::getRoleName).isOr(
                System.out::println,
                ()-> System.out.println("isOr")
        );
        String s = Null.no(userEntity).no(UserEntity::getRoleData).no(RoleEntity::getRoleName).get();
        System.out.println(s);
    }
}


测试结果:
Java-无敌空处理,保证你没见过(独此一家,比Optional好用100倍),所有文章,java,算法,开发语言,设计模式

如果链路过程出现了空的情况,在特定的方法中会将链路跟随者报错打印出来

Java-无敌空处理,保证你没见过(独此一家,比Optional好用100倍),所有文章,java,算法,开发语言,设计模式
-> 表示正常
? 表示这个是空的

以上是我自己研发出来的,只展示了一小部分,还有,中断处理继续判断,集合空处理等,直接就原地起飞, 上面案例给你们一个灵感自行写代码把, 下一个猝死的就是你了。

(上代码放在目前市面上的各种语言中都是王炸级别的,都没有这样能做到的,哦对了js6+ 有个?语法可以满足一部分,但是局限太大了)文章来源地址https://www.toymoban.com/news/detail-809698.html

加入博主语雀知识库,查看最新文章和技术
点击查看,点击查看,点击查看,点击查看
点赞 -收藏 -关注
有问题在评论区或者私信我-收到会在第一时间回复

到了这里,关于Java-无敌空处理,保证你没见过(独此一家,比Optional好用100倍)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 关于.Net和Java的看法——我见过最牛的一个小实习生经历

    笔者( 小方同学在学习 )是一个专科院校的一名普通学生,目前就职于某三线城市的WEB方面.Net开发实习生,在找实习期间和就业期间的一些看法,发表此文,纯个人想法,欢迎讨论,指正!哈哈轻点喷~ 在校学习技术方面也是.Net方面,所以实习就是.Net开发实习生。我也很喜

    2023年04月08日
    浏览(34)
  • HBase的事务处理与一致性保证

    HBase是一个分布式、可扩展、高性能的列式存储系统,基于Google的Bigtable设计。它是Hadoop生态系统的一部分,可以与HDFS、MapReduce、ZooKeeper等组件集成。HBase具有高可靠性、高性能和高可扩展性等特点,适用于大规模数据存储和实时数据处理。 在现实应用中,事务处理和一致性

    2024年02月20日
    浏览(38)
  • 【钱处理】商业计算怎样才能保证精度不丢失

    以项目驱动学习,以实践检验真知 很多系统都有「处理金额」的需求,比如电商系统、财务系统、收银系统,等等。只要和钱扯上关系,就不得不打起十二万分精神来对待,一分一毫都不能出错,否则对系统和用户来说都是灾难。 保证金额的准确性主要有两个方面: 溢出

    2024年02月12日
    浏览(34)
  • 如何保证分布式系统中服务的高可用性:应对 ZooKeeper Leader 节点故障的注册处理策略

    作者:zhaokk 在现代分布式系统中,高可用性是一个至关重要的。分布式系统中的各个组件需要保证在各种异常情况下仍然能够正常工作,确保系统的稳定性和可靠性。ZooKeeper(以下简称为zk)作为一种常用的分布式协调服务,为分布式系统中的各种任务提供了基础支持

    2024年02月11日
    浏览(55)
  • 如何有效保证Java代码单元测试覆盖率

    我们在实际项目开发过程中,不同level的童鞋由于专业技能的层次不同,导致在参与实际开发的业务代码中经常会出现各种bug,项目管理中好的pm或许会给充足的时间来让开发童鞋们定位修复这些bug,也有各种客观原因的PM不会在项目中预留这些时间,往往就需要开发自己通过

    2023年04月17日
    浏览(34)
  • java面试题(23):Spring Bean如何保证并发安全

    1 问题分析 我们知道默认情况下,Spring中的Bean是单例的,所以在多线程并发访问的时候,有可能会出现线程安全问题。 2 解决方案 有几个方面的解决思路: 我们可以设置Bean的作用域设置为原型(prototype),这样每次从容器中获取该 Bean 的时候,都会创建一个新的实例,避免

    2024年01月18日
    浏览(32)
  • Java 设计模式 - 单例模式 - 保证类只有一个实例

    单例模式是一种创建型设计模式,它确保一个类只有一个实例,并提供一个全局访问点来获取该实例。在某些情况下,我们需要确保一个类的实例在整个应用程序中是唯一的,这时候单例模式就非常有用。在本篇博客中,我们将详细探讨单例模式的概念、实现方式以及如何在

    2024年02月15日
    浏览(33)
  • 提高程序的健壮性:异常处理机制可以避免程序因错误而崩溃,让程序在某些情况下可以沉默”,从而保证程序的运行安全;

    作者:禅与计算机程序设计艺术 在软件开发过程中,随着应用的不断迭代更新、功能的增加、人员的变动等原因,软件的质量会逐渐下降,出现各种各样的bug、缺陷、漏洞等。这些bug或许能够影响系统的正常运行,或者导致系统崩溃甚至数据丢失。因此,如何在软件的设计中

    2024年02月11日
    浏览(35)
  • 速学数据结构 | 用队列实现栈你都被难住了?那是你没掌握好技巧

    🎬 鸽芷咕 :个人主页  🔥个人专栏 :《Linux深造日志》《C++干货基地》 ⛺️生活的理想,就是为了理想的生活!    🌈 hello! 各位铁铁们大家好啊,栈和队列我们都学过了那么试试用队列实现栈你会嘛?。    ⛳️ 本篇文章就来给大家来篇如何用队列来实现栈的全部解

    2024年02月05日
    浏览(33)
  • 网络工程师生涯中必玩的六款网络模拟器,有没有你没玩过的?

    你好,这里是网络技术联盟站。 作为网络工程师,大家一定用过各种各样的模拟器,开始入门的时候大家会选择一个厂商进行系统化学习,进入工作单位后,会由于项目的原因接触各种厂商的设备,这个时候想要快速熟悉其命令,最好的办法就是用相关厂商适应的模拟器去模

    2024年02月11日
    浏览(27)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包