c# - 对象模型,正确或最直观的方式

标签 c# object inheritance

我正在尝试找出设置此模型的最佳方法。我几乎以一种方式做到了,但我正在考虑另一种方式。这是一次学习经历,所以浪费时间并不重要。

namespace FirstWay
 {

public class CrateOfBags
{
    public string crateId { get; set; }
    public string originCountry { get; set; }
    public List<BagOfApples> bagList { get; set; }
}

public class BagOfApples
{
    public double weight { get; set; }
    public string bagId { get; set; }
    public List<apple> appleList { get; set; }
}

public class apple
{
    public string appleId { get; set; }
    public string color { get; set; }
    public Boolean rotten { get; set; }
}
}

//或这个
 namespace SecondWay
   {
public class CrateOfBags
{
    public string crateId { get; set; }
    public string originCountry { get; set; } 
}

public class BagOfApples : CrateOfBags
{
    public string bagId { get; set; }
    public double weight { get; set; }
}

public class apple : BagOfApples
{
    public string appleId {get;set;}
    public string color { get; set; }
}

}

可能的问题

苹果问题:
交付了多少烂苹果?
烂苹果来自哪些袋子和/或哪些 crate ?
第一种方式:可以遍历每个 crate ,然后是袋子,然后是苹果和计数。
第二种方式:可以循环遍历苹果并将父属性添加到 HashSet(一种防止重复的方法)

crate 问题。查找每个国家/地区的 crate 数量?
第一种方式:循环遍历箱子并保留一个计数列表、数组等。
第二种方式:必须遍历所有苹果并且只关心 crate 。

我遇到的一个问题是我对苹果作为它自己的实体知之甚少。我只知道它来自哪个 crate ,方法是从 crate 启动 foreach 循环

但是,如果我想问一个问题,例如“特定批处理中有多少青苹果(按 id)?”我也有问题,具体取决于方式。

说苹果是袋子的 child ,就像狗是动物的 child 一样,对我来说似乎很尴尬。然而,我喜欢能够自由移动操纵苹果的想法,例如通过更改父属性 bagid 来切换它们所在的包。我并不是在寻找特定问题的解决方案,而只是其中一个比另一个更好(更灵活、更高效、更直观),或者我完全错过了一些东西,比如使用另一种技术。非常感谢。

附言这不是真正的模型,而是一个相当不错的表示。

最佳答案

从数据建模的角度来看,第二种方法显然是错误的:苹果不是 BagOfApples。继承应该创造可替代性:你能总是把苹果放在需要 BagOfApples 的地方吗?我不这么认为。这是 Liskov 替换原则(它被违反了)。

在数据库方面,第二个模型是非规范化的。它可以通过将所有 3 个表连接在一起从第一个模型创建,从而创建冗余数据。这是一种反模式,因为当您更改某些内容时,您必须在多个地方进行更改(如果您忘记这是无声的数据损坏)。

关于c# - 对象模型,正确或最直观的方式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14991484/

相关文章:

c++ - 获取虚基类的继承路径

C++类类型数组

c# - visual studio 中自动完成属性的快捷方式?

c# - 查找特定子文件夹

java - 确保套接字编程中的数据传递

javascript - 使用带有 obj 的数组索引来删除项目或更改 obj 内的标志

javascript - 如何从 JavaScript 中的变量值创建对象属性?

c++ - 扩展模板抽象类时出错

c# - 如何使用某些客户端工具将批量数据插入 Membase Server 1.6

c++ - 对列表中的每个对象调用成员函数,改变对象所在的列表