deprecate OptionalBean

This commit is contained in:
Looly
2021-09-02 13:56:19 +08:00
parent 614754c9ba
commit 4a384f6a5c
4 changed files with 30 additions and 71 deletions

View File

@@ -3,12 +3,13 @@
------------------------------------------------------------------------------------------------------------- -------------------------------------------------------------------------------------------------------------
# 5.7.12 (2021-09-01) # 5.7.12 (2021-09-02)
### 🐣新特性 ### 🐣新特性
* 【system 】 OshiUtil增加getCurrentProcess方法 * 【system 】 OshiUtil增加getCurrentProcess方法
* 【extra 】 SpringUtil增加getApplicationName、publishEvent方法issue#I485NZ@Gitee * 【extra 】 SpringUtil增加getApplicationName、publishEvent方法issue#I485NZ@Gitee
* 【core 】 BeanUtil.getProperty增加判空issue#I488HA@Gitee * 【core 】 BeanUtil.getProperty增加判空issue#I488HA@Gitee
* 【core 】 OptionalBean弃用pr#1182@Github
### 🐞Bug修复 ### 🐞Bug修复

View File

@@ -15,7 +15,9 @@ import java.util.function.Supplier;
* @param <T> Bean类型 * @param <T> Bean类型
* @author totalo * @author totalo
* @since 5.4.7 * @since 5.4.7
* @deprecated {@link java.util.Optional} 可以完成此类的所有功能。
*/ */
@Deprecated
public final class OptionalBean<T> { public final class OptionalBean<T> {
private static final OptionalBean<?> EMPTY = new OptionalBean<>(); private static final OptionalBean<?> EMPTY = new OptionalBean<>();

View File

@@ -1,50 +0,0 @@
package cn.hutool.core.bean;
import org.junit.Assert;
import lombok.Data;
import org.junit.Test;
public class OptionalBeanTest {
@Test
public void optionalBeanTest() {
User user = new User();
user.setName("hello");
String value1 = OptionalBean.ofNullable(user)
.getBean(User::getSchool)
.getBean(User.School::getAddress).get();
Assert.assertNull(value1);
boolean present = OptionalBean.ofNullable(user)
.getBean(User::getSchool)
.getBean(User.School::getAddress).isPresent();
Assert.assertFalse(present);
String value2 = OptionalBean.ofNullable(user)
.getBean(User::getSchool)
.getBean(User.School::getAddress).orElse("没得地址");
Assert.assertEquals(value2, "没得地址");
try {
OptionalBean.ofNullable(user)
.getBean(User::getSchool)
.getBean(User.School::getAddress).orElseThrow(() -> new RuntimeException("空指针了"));
} catch (Exception e) {
Assert.assertEquals(e.getMessage(), "空指针了");
}
}
@Data
public static class User {
private String name;
private String gender;
private School school;
@Data
public static class School {
private String name;
private String address;
}
}
}

View File

@@ -1,6 +1,5 @@
package cn.hutool.json; package cn.hutool.json;
import cn.hutool.core.bean.OptionalBean;
import cn.hutool.core.convert.Convert; import cn.hutool.core.convert.Convert;
import cn.hutool.core.convert.ConvertException; import cn.hutool.core.convert.ConvertException;
import cn.hutool.core.date.DateUtil; import cn.hutool.core.date.DateUtil;
@@ -10,6 +9,7 @@ import cn.hutool.core.util.StrUtil;
import java.time.LocalDateTime; import java.time.LocalDateTime;
import java.util.Date; import java.util.Date;
import java.util.Optional;
/** /**
* 用于JSON的Getter类提供各种类型的Getter方法 * 用于JSON的Getter类提供各种类型的Getter方法
@@ -114,24 +114,27 @@ public interface JSONGetter<K> extends OptNullBasicTypeFromObjectGetter<K> {
} }
@Override @Override
default Date getDate(K key, Date defaultValue){ default Date getDate(K key, Date defaultValue) {
// 默认转换 // 默认转换
final Object obj = getObj(key); final Object obj = getObj(key);
if (null == obj) { if (null == obj) {
return defaultValue; return defaultValue;
} }
if(obj instanceof Date){ if (obj instanceof Date) {
return (Date) obj; return (Date) obj;
} }
String format = OptionalBean.ofNullable(getConfig()).getBean(JSONConfig::getDateFormat).get(); final Optional<String> formatOps = Optional.ofNullable(getConfig()).map(JSONConfig::getDateFormat);
if(StrUtil.isNotBlank(format)){ if (formatOps.isPresent()) {
// 用户指定了日期格式,获取日期属性时使用对应格式 final String format = formatOps.get();
final String str = Convert.toStr(obj); if (StrUtil.isNotBlank(format)) {
if(null == str){ // 用户指定了日期格式,获取日期属性时使用对应格式
return defaultValue; final String str = Convert.toStr(obj);
if (null == str) {
return defaultValue;
}
return DateUtil.parse(str, format);
} }
return DateUtil.parse(str, format);
} }
return Convert.toDate(obj, defaultValue); return Convert.toDate(obj, defaultValue);
@@ -140,29 +143,32 @@ public interface JSONGetter<K> extends OptNullBasicTypeFromObjectGetter<K> {
/** /**
* 获取{@link LocalDateTime}类型值 * 获取{@link LocalDateTime}类型值
* *
* @param key 键 * @param key
* @param defaultValue 默认值 * @param defaultValue 默认值
* @return {@link LocalDateTime} * @return {@link LocalDateTime}
* @since 5.7.7 * @since 5.7.7
*/ */
default LocalDateTime getLocalDateTime(K key, LocalDateTime defaultValue){ default LocalDateTime getLocalDateTime(K key, LocalDateTime defaultValue) {
// 默认转换 // 默认转换
final Object obj = getObj(key); final Object obj = getObj(key);
if (null == obj) { if (null == obj) {
return defaultValue; return defaultValue;
} }
if(obj instanceof LocalDateTime){ if (obj instanceof LocalDateTime) {
return (LocalDateTime) obj; return (LocalDateTime) obj;
} }
String format = OptionalBean.ofNullable(getConfig()).getBean(JSONConfig::getDateFormat).get(); final Optional<String> formatOps = Optional.ofNullable(getConfig()).map(JSONConfig::getDateFormat);
if(StrUtil.isNotBlank(format)){ if (formatOps.isPresent()) {
// 用户指定了日期格式,获取日期属性时使用对应格式 final String format = formatOps.get();
final String str = Convert.toStr(obj); if (StrUtil.isNotBlank(format)) {
if(null == str){ // 用户指定了日期格式,获取日期属性时使用对应格式
return defaultValue; final String str = Convert.toStr(obj);
if (null == str) {
return defaultValue;
}
return LocalDateTimeUtil.parse(str, format);
} }
return LocalDateTimeUtil.parse(str, format);
} }
return Convert.toLocalDateTime(obj, defaultValue); return Convert.toLocalDateTime(obj, defaultValue);