我在想出一种干净的方法来实现我的分层时遇到了麻烦。
这是我拥有的层(下层支持上层,要么通过继承 或组合):
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/