Java购物车用HashMap管理商品,CartItem含名称、单价、数量及getSubtotal()等方法,Cart类封装增删改查与总价计算,支持控制台演示和后续序列化扩展。

Java中实现简单购物车,核心是用集合(如HashMap或ArrayList)管理商品信息,配合增删改查操作。不需要数据库也能模拟基本业务逻辑,重点在于数据结构设计和状态维护。
用HashMap存储商品:键为商品ID,值为商品对象
推荐用HashMap
- 添加商品时,先检查ID是否存在:存在则数量+1;不存在则新建CartItem并put进去
- 修改数量直接更新对应CartItem的quantity字段
- 删除商品调用remove(key)即可
CartItem类要封装基础行为
别只写getter/setter,建议在CartItem里加一个getSubtotal()方法,返回单价×数量,这样计算总价时更清晰,也便于后续扩展(比如加折扣)。
- 构造方法建议支持“商品+单价+数量”三参数,初始化更安全
- 重写toString(),调试时打印购物车内容一目了然
- 可加validate()方法检查数量是否大于0,防止脏数据
购物车类(Cart)提供统一操作接口
把add、remove、update、clear、getTotalPrice等方法都封装在Cart类里,外部只跟Cart打交道,符合面向对象的封装原则。
立即学习“Java免费学习笔记(深入)”;
- getTotalPrice()遍历HashMap所有CartItem,累加getSubtotal()
- getList()可返回values()集合转成ArrayList,方便前端或控制台展示
- 清空购物车用map.clear(),比循环remove更高效
控制台简单演示:不用框架也能跑起来
写个main方法,new Cart(),手动add几个商品,再print总金额和明细——这是验证逻辑最直接的方式。
- 示例ID可用字符串如"p001"、"p002",避免int型ID导致自动装箱干扰理解
- 测试边界:添加相同ID两次、删不存在的ID、数量减到0后是否自动移除(可选)
- 后续想持久化?只需把HashMap序列化到文件,或对接JDBC
基本上就这些。不复杂但容易忽略细节,比如没处理空指针、没校验数量、忘记更新总价缓存。写完多跑几遍测试用例,逻辑就稳了。










