Java接口返回值为什么不使用枚举

这篇文章主要介绍“Java接口返回值为什么不使用枚举”,在日常操作中,相信很多人在Java接口返回值为什么不使用枚举问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Java接口返回值为什么不使用枚举”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

创新互联是一家专业的成都网站建设公司,我们专注做网站、成都做网站、网络营销、企业网站建设,买链接广告投放为企业客户提供一站式建站解决方案,能带给客户新的互联网理念。从网站结构的规划UI设计到用户体验提高,创新互联力求做到尽善尽美。

比如星巴克提供了 0.0.1 版本的二方库,定义了一个 Starbucks 类,里面包含了枚举类型的 SizeEnum,里面分别是中杯、大杯、特大杯。

public class Starbucks implements Serializable {
 private Long id;
 private String name;
 private Integer capacity;
 private SizeEnum sizeEum;
}

public enum SizeEnum {
 TALL(1),
 GRANDE(2),
 VENTI(3)
}
 

定义了一个服务类,实现了根据 id 获取星巴克的方法:

public class StarbucksImpl implements StarbucksService {
 public Starbucks getStarbucksById(Long id) {
   Starbucks starbucks = new Starbucks();
   starbucks.setId(1L);
   starbucks.setName("Latte");
   starbucks.setCapacity(360);
   starbucks.setSizeEnum(SizeEnum.TALL);
   return starbucks;
 }
}
 

然后,星巴克的门店引入 0.0.1 这个版本 jar 包,然后卖的好好的:

public class StarbucksDemo {
 @Resource
 private StarbucksService starbucksService;
 
 public void getStarbucks() {
   Starbucks starbucks = starbucksService.getStarbucksById(1L);
   System.out.println(starbucks);
 }
}
 

有一天,老罗说要那个中等大小的中杯拿铁,但是服务员说那是大杯,经过一番争论,罗老师很是生气。

 

于是星巴克升级到了 0.0.2 版本二方库,在枚举类 SizeEnum 中新增了小杯,升级后的枚举类如下:

public enum SizeEnum {
 TALL(1),
 GRANDE(2),
 VENTI(3),
 SHORT(4)
}
 

同时服务类的接口方法也做了相应修改:

public class StarbucksImpl implements StarbucksService {
 public Starbucks getStarbucksById(Long id) {
   Starbucks starbucks = new Starbucks();
   starbucks.setId(1L);
   starbucks.setName("Latte");
   starbucks.setCapacity(240);
   starbucks.setSizeEnum(SizeEnum.SHORT);
   return starbucks;
 }
}
 

由于星巴克的门店比较多,有的还不知道这个新加的需求,因此返回结果中出现了 SHORT,但是 0.0.1 版本的二方库中没有小杯啊,所以就出问题了,也就是序列化失败。

通过这个例子,我相信大家对枚举类型作为返回结果有了一定的理解,下面引用孤尽大佬在知乎的回答:

由于升级原因,导致双方的枚举类不尽相同,在接口解析,类反序列化时出现异常。

Java 中出现的任何元素,在 Gosling 的角度都会有背后的思考和逻辑(尽管并非绝对完美,但 Java 的顶层抽象已经是天才级了),比如:接口、抽象类、注解、和本文提到的枚举。枚举有好处,类型安全,清晰直接,还可以使用等号来判断,也可以用在 switch 中。它的劣势也是明显的,就是不要扩展。可是为什么在返回值和参数进行了区分呢,如果不兼容,那么两个都有问题,怎么允许参数可以有枚举。当时的考虑,如果参数也不能用,那么枚举几乎无用武之地了。参数输出,毕竟是本地决定的,你本地有的,传送过去,向前兼容是不会有问题的。但如果是接口返回,就比较恶心了,因为解析回来的这个枚举值,可能本地还没有,这时就会抛出序列化异常。

比如:你的本地枚举类,有一个天气 Enum:SUNNY, RAINY, CLOUDY,如果根据天气计算心情的方法:guess(WeatcherEnum xx),传入这三个值都是可以的。返回值:Weather guess(参数),那么对方运算后,返回一个 SNOWY,本地枚举里没有这个值,傻眼了。

到此,关于“Java接口返回值为什么不使用枚举”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注创新互联网站,小编会继续努力为大家带来更多实用的文章!


分享文章:Java接口返回值为什么不使用枚举
本文路径:http://scyanting.com/article/jgsidc.html