我是一个相当新手的程序员,正在尝试学习 n 层架构(DAL、BLL、UI)的基础知识。我正在编程的应用程序是用 VB.NET (.Net 3.5) 编写的单层 3 层应用程序。图层如下:
达尔
BLL
用户界面
COMMON - 现在包含 DTO。
我无法确定在 BLL 和 UI 之间传递什么。我的直觉告诉我,我应该只将数据传递给 UI,而不是来自 BLL 的完整业务对象。考虑两种情况:
1) 将 BO 直接从 BLL 传递到 UI。这暴露了 BO 方法并允许 UI 直接访问 BO,这似乎很糟糕。
2) 仅将相关数据从 BO 传递到 UI。例如,客户有姓名和地址。这些数据确实是我们想要在 UI 中显示/编辑的内容,因此我们只会将该数据返回到 UI 而不是完整的 BO。UI 然后会调用 BLL 来更新特定的 BO。
我倾向于使用#2,但我不知道实现它的最佳方法。我现在的编程方式是,如果我只从 BLL 返回数据,所有对我的 BO 的引用都将丢失,GC 将声明它们。基于此,我有一些问题:
1) 我应该在调用 BLL 之间保持业务对象处于活动状态吗?另一种方法是每次通过 BLL 传递数据时重新创建它们,这似乎是错误的。
2)在单层架构中保持 BO 存活的最佳方式是什么(如果我们不将引用传递给 UI,如何保存它?)
3) n 层应用程序如何做到这一点?他们是否让 BO 在 BLL 中存活并等待来自 UI 的更新?这是否需要在 BLL 中进行大量“簿记”以确保在不再需要 BO 时释放它们?
感谢您的任何见解,如果我问一些愚蠢的问题,请原谅我。我自学了一些我知道的小程序,所以我可能会问一个愚蠢的问题并且不知道。