如何正确从购物车中移除商品:解决 remove() 方法失效问题

购物车中的 remove(Fiction) 方法无法真正删除商品,根本原因在于 Fiction 实体未重写 equals() 方法,导致 Iterator.remove() 无法识别目标对象。本文将详解问题根源、修复方案及最佳实践。

购物车中的 `remove(Fiction)` 方法无法真正删除商品,根本原因在于 `Fiction` 实体未重写 `equals()` 方法,导致 `Iterator.remove()` 无法识别目标对象。本文将详解问题根源、修复方案及最佳实践。

在您提供的代码中,Cart.remove(Fiction fiction) 方法看似逻辑完整:遍历列表、比对相等性、调用 iterator.remove() 并更新总价。但实际运行时商品始终残留——这并非流程错误,而是 Java 对象比较机制的典型陷阱。

关键问题出在这一行:

if(item.equals(fiction)) { ... }

默认的 Object.equals() 仅比较引用地址(即是否为同一内存对象)。而您的控制器中通过 fictionRepo.findById(id) 查询得到的是数据库新加载的实体实例,与购物车中已添加的 Fiction 对象(即使 ID 相同)内存地址不同,因此 equals() 永远返回 false,循环跳过所有项,删除操作形同虚设。

✅ 正确解法:为 Fiction 类重写 equals()(以及配套的 hashCode(),遵循契约):

@Entity
public class Fiction {
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;

    private String title;
    private float prezzo; // 注意:建议使用 BigDecimal 存储金额

    // 其他字段、getter/setter...

    @Override
    public boolean equals(Object o) {
        if (this == o) return true;
        if (o == null || getClass() != o.getClass()) return false;
        Fiction fiction = (Fiction) o;
        return Objects.equals(id, fiction.id); // 仅基于主键判断逻辑相等
    }

    @Override
    public int hashCode() {
        return Objects.hash(id);
    }
}

⚠️ 重要注意事项:

? 进阶优化建议:

综上,修复 equals() 是解决问题的最小必要改动,但结合作用域、精度与健壮性改进,才能构建真正可靠的购物车模块。

本文转载于:互联网 如有侵犯,请联系zhengruancom@outlook.com删除。
免责声明:正软商城发布此文仅为传递信息,不代表正软商城认同其观点或证实其描述。