ArrayList比数组更适用商品管理,因其自动扩容、动态增删;需重写equals()和hashCode(),用unmodifiableList()封装,高频查找补HashMap,排序需求用TreeSet(注意Comparable或Comparator实现),删除需同步清理关联数据。

用 ArrayList 存商品对象比用数组更实际
数组长度固定,增删商品时要手动扩容、复制,容易出错;ArrayList 自动处理容量增长,且支持动态增删。别为了“学过数组”硬套——商品数量随时变,ArrayList 是默认起点。
注意点:
-
Product类必须重写equals()和hashCode(),否则remove()或contains()可能失效 - 避免直接暴露内部
ArrayList引用,用Collections.unmodifiableList()包一层防止外部误改 - 如果频繁按 ID 查找,单靠
ArrayList遍历效率低,得补HashMap做索引
用 TreeSet 实现按价格自动排序的库存视图
用户想看“最便宜的 5 款商品”,或后台导出“价格升序报表”,这时候别每次 Collections.sort()——用 TreeSet 内置红黑树,插入即排序,first()、headSet() 直接拿结果。
但必须注意:
立即学习“Java免费学习笔记(深入)”;
-
TreeSet要求元素可比较,要么Product实现Comparable(推荐按price升序),要么传入Comparator - 不能存重复价格的商品?那就得在
compareTo()里加入第二排序字段(如id),否则相同价格会被视为重复而丢弃 -
TreeSet不保留插入顺序,也不支持随机访问(没有get(int index))
用 HashMap 快速查商品,但键别用中文名当 key
用户输入“iPhone 15”,你想秒回商品信息?用 HashMap 是对的,但键必须是唯一、稳定、无歧义的标识符。
常见翻车点:
- 用商品名称作 key:同名不同型号(如“Redmi Note 13”有 4G/5G 版)、中英文混输、空格/标点不一致,查不到
- 用
id字段作 key 最稳妥,数据库主键或系统生成 UUID 都行 - 如果业务真要支持“模糊搜名称”,那是另一层逻辑——先用
HashMap查精确 ID,再额外建List配合stream().filter()做文本匹配
删除商品时,集合引用和关联数据要同步清理
一个商品被删,不只是从 ArrayList 里 remove() 就完事。比如你还有个 Map 记录各商品被下单记录——不清理,后续统计销量就出错。
实操建议:
- 封装删除动作到方法里,比如
deleteProduct(String productId),内部统一处理主集合 + 所有衍生索引(HashMap、TreeSet) - 如果用了多个集合存同一份数据,别用 “深拷贝对象” 来隔离——改用
WeakReference或直接共享引用,靠逻辑控制生命周期 - 测试时重点覆盖“删完再查”“删完再排序”“删完再统计”,很多 bug 出现在状态不同步









