开发者社区> 问答> 正文

针对Set 对象排重,Java如何避坑?

已解决

针对Set 对象排重,Java如何避坑?

展开
收起
游客lmkkns5ck6auu 2022-10-26 16:25:14 419 0
1 条回答
写回答
取消 提交回答
  • 推荐回答

    1) 当确定数据唯一时,可以使用 List 代替 Set 当确定解析的城市数据唯一时,就没有必要进行排重操作,可以直接使用 List 来存储。 List cityList = new ArrayList<>(1024); Iterator iterator = parser.iterator(); while (iterator.hasNext()) { cityList.add(parseCity(iterator.next()));} return cityList;

    2) 当确定数据不唯一时,可以使用 Map 代替 Set 当确定解析的城市数据不唯一时,需要安装城市名称进行排重操作,可以直接使用Map 进行存储。首先,不希望把业务逻辑放在模型 DO 类中;其次,把排重字段放在代码中,便于代码的阅读、理解和维护。

    3) 遵循 Java 语言规范,重写 hashCode 方法和 equals 方法 不重写 hashCode 方法和 equals 方法的自定义类不应该在 Set 中使用。

    以上内容摘自《Java工程师必读手册》电子书,点击https://developer.aliyun.com/ebook/download/7780 可下载完整版

    2022-10-26 19:51:52
    赞同 展开评论 打赏
来源圈子
更多
收录在圈子:
阿里云开发者社区官方技术圈,用户产品功能发布、用户反馈收集等。
问答排行榜
最热
最新

相关电子书

更多
Spring Cloud Alibaba - 重新定义 Java Cloud-Native 立即下载
The Reactive Cloud Native Arch 立即下载
JAVA开发手册1.5.0 立即下载