首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

使用Optioanl优雅的处理空值

尤其是对接口的抽象,它在设计和开发中占很大的比重,我们在开发时希望尽量面向接口编程。...如果调用者忽略了注释,有可能就对业务系统产生了风险,这个风险有可能导致一个亿! 除了以上这种”弱提示”的方式,还有一种方式是,返回值是有可能为空的。那要怎么办呢?...空集合返回值 : 如果有集合这样返回值时,除非真的有说服自己的理由,否则,一定要返回空集合,而不是null Optional: 如果你的代码是jdk8,就引入它!...(我想说,其实你的实体中的字段应该都是由业务含义的,会认真的思考过它存在的价值的,不能因为Optional的存在而滥用) 我们应该更关注于业务,而不只是空值的判断。...小结 可以这样总结Optional的使用: 当使用值为空的情况,并非源于错误时,可以使用Optional!Optional不要用于集合操作!

1.9K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Git提交时使用.gitignore文件忽略特殊文件

    在工作中或者日常开发中,我们使用 Git 进行开发上传至 Github 等托管平台,有些时候,我们必须把某些文件放到 Git 的工作目录中,但是又不能提交它们,比如保存了数据库密码的配置文件、ide 的配置文件等等...,Git 就会自动忽略这些文件 忽略文件的原则是: 忽略操作系统自动生成的文件,比如缩略图等 忽略编译生成的中间文件、可执行文件等,也就是如果一个文件是通过另一个文件自动生成的,那自动生成的文件就没必要放进版本库...,比如ThinkPHP5框架产生的runtime文件 忽略你自己的带有敏感信息的配置文件,比如ThinkPHP5框架根目录下的.env配置数据库文件 举个栗子 使用 ThinkPHP5 框架进行开发,使用...如果你确实想添加该文件,可以用-f强制添加到 Git $ git add -f .idea 所以在使用 Git 的时候想要忽略某些文件时,需要编写.gitignore 沈唁志|一个PHPer的成长之路...原创文章采用CC BY-NC-SA 4.0协议进行许可,转载请注明:转载自:Git提交时使用.gitignore文件忽略特殊文件

    2.7K30

    新手使用 Vue 时易忽略而导致的 Bug

    一个萌新在初次独立使用 Vue 这个框架时,难免会出现很多意外的,我也是在这条路上跌跌撞撞,遇到了很多看似很奇怪的 Bug,却怎么也不知道哪里错了。...路由和导航 在 Vue 中,路由一般是由 Vue-router 实现的,在主页面中(View)存在一个 router-view 的标签,当地址发生改变时,仅仅会在 router-view 中的部分会被重载...根据 Vue 生命周期, $refs 内的元素在 mounted 后才能使用。 在 created() 中如需调用,可以使用 setTimeOut() 的特征来实现。...$refs.dom)) 3} COPY Array 内部元素监听问题 在父子组件传参时,如果父组件使用数组内的元素传参,之后数组内的元素在父组件被直接赋值修改,Vue将无法监听到变化。...导致父组件里的元素看似改变了,但是子组件的值仍然没有改变。 请使用 this.$set(targetArray, index, value) 对 Array 赋值. 其他 还请大佬指正。

    50330

    Mybatis查询结果为空时,为什么返回值为NULL或空集合?

    目录 背景 JDBC 中的 ResultSet 简介 简单映射 回归最初的问题:查询结果为空时的返回值 结论 背景 一行数据记录如何映射成一个 Java 对象,这种映射机制是 MyBatis 作为 ORM...当返回行的所有列都是空时,MyBatis 默认返回 null。当开启这个设置时,MyBatis会返回一个空实例。 请注意,它也适用于嵌套的结果集(如集合或关联)。...回归最初的问题:查询结果为空时的返回值 | 返回结果为单行数据 可以从 ResultSetHandler的handleResultSets 方法开始分析。...所以不管是集合类型还是普通对象,Mybatis 都会先初始化一个 List 存储结果,然后返回值为普通对象且查为空的时候,selectOne 会判断然后直接返回 NULL 值。...而返回值为集合对象且查为空时,selectList 会把这个存储结果的 List 对象直接返回,此时这个 List 就是个空集合。

    5.4K20

    返回非空值函数LastnonBlank的第2参数使用方法

    非空值函数LastnonBlank第2参数使用方法 LastnonBlank(,) 参数 描述 column 列名或者具有单列的表,单列表的逻辑判断 expression...如果我们第二参数只写一个常数,则等同于返回列表的最大值,主要差异表现在汇总合计上。 有2张表,一张是余额表,另外一张是日历表,并做关系链接。 ? ? 我们来看下3种写法,返回的不同结果。...解释:带常数的LastnonBlank度量值,不会显示汇总,因为只返回日期列里的最大值。因为LastnonBlank是根据ACISS大小来返回最后一个,也就是返回ACISS的最大值。...第1个度量,既然知道第2参数是常数,也就是返回最大值,日历筛选的时候,因为汇总的时候是没有指定值的,所以返回为空白。 第2个度量,是在日历表上进行筛选后进行返回最后日期,所以返回的也不带有汇总。

    2K10

    Python中使用deepdiff对比json对象时,对比时如何忽略数组中多个不同对象的相同字段

    最近忙成狗了,很少挤出时间来学习,大部分时间都在加班测需求,今天在测一个需求的时候,需要对比数据同步后的数据是否正确,因此需要用到json对比差异,这里使用deepdiff。...一般是用deepdiff进行对比的时候,常见的对比是对比单个的json对象,这个时候如果某个字段的结果有差异时,可以使用exclude_paths选项去指定要忽略的字段内容,可以看下面的案例进行学习:...那么如果数据量比较大的话,单条对比查询数据效率比较低,因此,肯呢个会调用接口进行批量查询,然后将数据转成[{},{},{}]的列表形式去进行对比,那么这个时候再使用exclude_paths就无法直接简单的排除某个字段了...除非自己一个个去指定要排除哪个索引下的字段,不过这样当列表的数据比较多的时候,这样写起来就很不方便,代码可读性也很差,之前找到过一个用法,后来好久没用,有点忘了,今晚又去翻以前写过的代码记录,终于又给我找到了,针对这种情况,可以使用...这里对比还遇到一个问题,等回头解决了再分享: 就这种值一样,类型不一样的,要想办法排除掉。要是小伙伴有好的方法,欢迎指导指导我。

    91420

    Excel技巧:使用上方单元格的值填充空单元格

    有时候,工作表列中有许多空单元格,而不是在每行都重复相同的内容,这样可以使报表更容易阅读,然而也会导致一些问题,例如不方便排序或筛选数据。...如下图1所示,在列A中有一些空单元格,如果对列A进行筛选,则只会出现有内容的单元格数据,因此空白单元格需要使用其上方单元格的内容填充。...图1 首先,选择包含空单元格的列,单击功能区“开始”选项卡“编辑”组中的“查找和选择——定位条件”,在弹出的“定位条件”对话框中勾选“空值”前的单选按钮。...最后,选择列A,复制数据,然后在所选列中单击右键,选择“粘贴值”命令。 完整的操作过程如下图2所示。 图2 如果你经常遇到填充空单元格的操作,那么可以使用宏来代替手工操作。...Cells.SpecialCells(xlCellTypeBlanks) On Error GoTo 0 If rng Is Nothing Then MsgBox "没有找到空单元格

    3.4K30

    fastJson使用toJSONString()时自动过滤掉值为null

    一、诱发原因 在做项目时候需要将json对象转化为String字符串,很自然的可以想到使用toJSONString方法,那么这里问题就来了,在使用该方法的时候发现了一个问题,当接收到的报文有null值时...,在转化为json字符串时为null的字段会被自动过滤掉,查询资料字后发现可以使用一些序列化的参数来处理这种情况 二、处理 JSONObject.toJSONString(result,SerializerFeature.WriteMapNullValue...); 使用这种方式给给方法添加序列化参数的方式可以做到将空值以null作为value保存,具体参数如下 QuoteFieldNames,//输出key时是否使用双引号,默认为true UseSingleQuotes...,//使用单引号而不是双引号,默认为false WriteMapNullValue,//是否输出值为null的字段,默认为false WriteEnumUsingToString,//Enum输出name...null的value存为空字串。

    8.3K00

    springmvc之使用ModelAttribute避免不允许被修改的值更新时为空

    我们在更新数据时,有的数据是不能够被修改的。假设User有三个字段,username,age,password。...我们在前端传过来的数据为username和age,不能修改password,一般情况下,在后端都会新建一个user对象,使用该user对象对数据库进行更新操作。...r那么我们直接进行更新操作,会导致密码变为空。 解决方案有以下两种: (1)将所需的password用隐藏域传过来。但是这种做法当有很多不必修改的字段时很麻烦。...(2)取出数据库中的password字段,重新为新建的user对象的password赋上值,这种操作也很麻烦。...(3)使用ModelAttribute注解,不新建一个user对象,而是在原有的基础上进行更新,就可以既更新字段,又可以保留不必更新的字段。

    1.3K20

    SQL 中的 NULL 值:定义、测试和处理空数据,以及 SQL UPDATE 语句的使用

    需要注意的是,NULL 值与零值或包含空格的字段不同。具有 NULL 值的字段是在记录创建期间留空的字段。 如何测试 NULL 值? 使用比较运算符(如=、)无法测试 NULL 值。...IS NOT NULL 运算符 IS NOT NULL 运算符用于测试非空值(非 NULL 值)。...使用 IS NULL 和 IS NOT NULL 运算符可以有效地处理数据库中的空值情况。 SQL UPDATE 语句 UPDATE 语句用于修改表中的现有记录。...UPDATE 语法 UPDATE 表名 SET 列1 = 值1, 列2 = 值2, ... WHERE 条件; 注意:在更新表中的记录时要小心!请注意UPDATE语句中的WHERE子句。...在更新记录时要小心。如果省略 WHERE 子句,将更新所有记录!

    59120
    领券