在不确定的情况下,我该如何区分价值对象和实体?

问题描述

最近我一直在阅读有关DDD中的价值对象和实体的信息。我了解这些概念的基础,但是我正在努力将这些概念应用于某些现实生活中。

据我所知,这些是价值对象和实体的特征:

值对象:

  • 没有特定的身份,其身份由其价值观组成。具有完全相同属性的两个值对象相等。
  • 是一成不变的。当您要更改值时,应将其丢弃并更换。
  • 没有生命周期/历史记录。

实体:

  • 具有身份,通常通过某种标识符。 (订单号,客户ID等)
  • 易变。
  • 具有生命周期和历史记录,属性可以更改,而且还是一样。

基于这些特征,我尝试为一个基本的网上商店建模。在此网上商店中,有几个类,我想将它们建模为实体和值对象。

假设我有一个Order类,其中包含一些订单行。这些订单行包含客户的快照和产品的快照。在伪代码中,它类似于以下内容

class Order {
    private OrderLine[] $orderLines;
    private string $orderNumber;
    private string $orderStatus;

    public function Order(string $orderNumber,string $orderStatus,OrderLine[] $orderLines)
    {
        $this->orderLines = $orderLines;
        $this->orderNumber = $orderNumber;
        $this->orderStatus = $orderStatus;
    }

    public function changeStatus(string $orderStatus): void
    {
        $this->orderStatus = $orderStatus;
    }
}

class OrderLine {
    private ProductSnapshot $product;
    private CustomerSnapshot $customer;
    private int $quantity;

    public function OrderLine(ProductSnapshot $product,CustomerSnapshot $customer,int $quantity)
    {
        $this->product = $product;
        $this->customer = $customer;
        $this->quantity = $quantity;
    }

    public function changeQuantity(int $quantity)
    {
        $this->quantity = $quantity;
    }
}

class ProductSnapshot {
    private string $name;
    private string $color;
    private string $price;

    public function ProductSnapshot(string $name,string $color,string $price)
    {
        $this->name = $name;
        $this->color = $color;
        $this->price = $price;
    }
}

class CustomerSnapshot {
    private string $name;
    private DateTime $age;

    public function CustomerSnapshot(string $name,DateTime $age)
    {
        $this->name = $name;
        $this->age = $age;
    }
}

我遇到的第一件事是OrderLine类。订单行本身实际上并没有身份,因为它没有标识符,并且值一起代表了一个对象。但是,客户可以更改数量,因此它具有某种生命周期/历史记录,对吗?我想听听您有关将其建模为值对象还是实体的想法。

我不确定的第二件事是快照(customerSnapshot和productSnapshot)。该名称表示这些对象没有历史记录,因为它们是快照。但是客户提供的名称可能有误,以后应进行编辑。在那种情况下,同样存在某种历史。另外,当您更改客户名称时,它可能仍然是同一位客户吗?即使我没有标识符。这样,我还想知道最适合这些快照,实体或值对象的是什么?

非常感谢。

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)