c# - 继承与组合——在 OOP 架构考虑中

标签 c# oop design-patterns inheritance composition

我在想出一种干净的方法来实现我的分层时遇到了麻烦。

这是我拥有的层(下层支持上层,要么通过继承 或组合):

Business Logic Layer (BLL)
Datastore Layer (DSL)
Database Layer (DBL), Web-Service Buffer (WSB)

当 BLL 对象发出获取请求 getRecords() 时,它会反过来要求 DSL 完成它。

然后 DSL 决定使用本地 DBL 还是使用 WSB(它与远程 Web 服务前端通信到“主”DB)。


选项 1 - 组合(BLL 有一个 DSL,DSL 有一个 DBL)


我的问题是,由于 DSL 和 DBL 对象由 BLL 组成,它们对包含的 BLL 一无所知,因此它们应该如何进行包含 BLL 字段的特定 DB 查询?


选项 2 - 继承(BLL:DSL,DSL:DBL)


即使较低层现在可以通过公共(public)/ protected 继承访问 BLL,问题仍然是 DSL 和 DBL 如何准确地知道要生成哪些特定的查询字符串。我想 BLL 可以保留一组静态字符串,但是这会产生双向依赖性,我认为这是一个非常有缺陷的设计,会带来可怕的后果。

注意:每个 BLL 都有一个对应的表,它被序列化到/反序列化。

注意:我不想使用反射,并且想限制泛型的使用(除非绝对没有其他方法。我正在为我的 WSB 使用 generics,它正在工作很好,尽管我最关心的是在 DSL 和 DBL 层中生成特定于 BLL 的查询字符串)。

注意:将有许多不同的 BLL 对象将使用 DSL 和 DBL 层,而不仅仅是一个(否则这将是微不足道的)。

public class BL1 
{
  private DSL _dsLayer;

  public getRecords() 
  {
    // ...
    _dsLayer.getRecords();
    // ...
  }
}

public class DSL 
{
  private DBL _dbLayer;
  private WSB _wsBuffer;

  public getRecords() 
  {
    if(_dbLayer.getRecords() != null)
    {
      return records;
    }
    else
    {
      return _wsBuffer.getRecords();
    }
  }
}

public class DBL
{
  private string _db = "file.db3";

  public getRecords()
  {
    select ????? - how to know what fields to grab
  }
}

感谢您抽出时间来回答这个问题,非常感谢。

最佳答案

你应该选择 Composition。我认为继承没有意义,因为它们是完全不同类型的实体,实际上一个不能继承另一个。他们将继承哪些领域?谁从谁那里继承?

BLL 需要传递“字段”列表才能到达 DSL。作为 DSL 方法的参数或以其他方式。 DSL 方法只接收一些字段列表作为参数并使用它们。我认为这是一个可行的解决方案。

此外,您应该在每一层创建接口(interface)并针对它们进行编程,而不是使用类型本身。因此,例如,在您编写的示例代码中,将 DBL 和 WSB 更改为 IDBL 和 IWSB。这将帮助您更好地测试并允许代码中的松散耦合。

public class DSL 
{
  private IDBL _dbLayer;
  private IWSB _wsBuffer;
....

}

关于c# - 继承与组合——在 OOP 架构考虑中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11525364/

相关文章:

c# - HtmlGenericControl 和 TagBuilder 之间的区别

design-patterns - 如何在这里避免循环依赖

iOS:用于填充异步获取数据的设计模式

c# - 抽象方法签名、继承和 "Do"命名约定

c# - LINQ to CheckBoxList 数据项

c# - C# 中的正则表达式大写替换

c# - 在 C# 控制台应用程序中获取 google 驱动程序中文件的 downloadUrl

java - REST 服务的异常层次结构

javascript OOP 不工作 : Uncaught TypeError: object is not a function

Java方法重载和调用