小议传统分层与新式分层,抑或与DDD分层
引言 |
本文提到的分层只是软件架构上的分层。文中的传统分层指的是传统的三层结构:UI(界面表现层),BLL(业务逻辑层),DAL(数据访问层)。文中提出的观点也都是个人的一点认识,与任何组织没有关系,如有异议,还请各位踊跃拍砖。
当然了,出现的这些问题,也可能只是我个人的问题,不代表每个人都存在。无则加勉,有则改正吧。如果是个人的问题,那就当是个人总结吧,大家看看就算了。
这里说到的传统分层,也有可能是我对于分层的错误理解造成的,但是我看见的不只是我的项目是这么的结构,很多的项目也都是这样的结构。里面的代码, 都和我理解的一样,至少可以说明,还是有一部分人犯了和我一样的错误。
传统分层 |
传统分层最大的问题就在于割裂了上层与下层之间的联系,把他们之间的关系变成了简单的接口调用,变成了完全的接口形式主义。同时,忽略了下层是为上层提供服务的,不是单独存在的,下层提供的服务应该受到上层的规约。当然,也不是说不可以提供更多的服务,但是至少应该提供上层需要的,然后再考虑提供一些“边角料”。
我们先看一个传统分层的解决方案结构。
相互之间的引用关系是:UI引用BLL、Entity、Common;BLL引用IDAL、Entity、Common;IDAL引用Entity;DAL引用IDAL、Entity、Common。
显示行号 复制代码 ? UI Code
private void button1_Click(object sender, EventArgs e) { _02_BLL.OrderBll orderBll = Common.ServiceLocator.LoadService<_02_BLL.OrderBll>(); orderBll.SubmitOrder(new _05_Entity.OrderEntity() { OrderSeqNo = "123", OrderAmount = 1000 }); }显示行号 复制代码 ? BLL Code
public class OrderBll { IOrderDal _orderDal; public OrderBll() { _orderDal = Common.ServiceLocator.LoadService<_03_IDAL.IOrderDal>(); } public bool SubmitOrder(OrderEntity order) { return _orderDal.Add(order); } }显示行号 复制代码 ? IDAL Code
public interface IOrderDal { bool Add(OrderEntity order); }显示行号 复制代码 ? DAL Code
public class OrderDal:_03_IDAL.IOrderDal { public bool Add(_05_Entity.OrderEntity order) { IDbConnection conn = new SqlConnection(); conn.Open(); IDbCommand comm = conn.CreateCommand(); IDbDataParameter param = comm.CreateParameter(); param.Direction = ParameterDirection.Input; param.DbType = DbType.String; param.ParameterName = "OrderSeqNo"; if (comm.ExecuteNonQuery() > 0) return true; else return false; } }显示行号 复制代码 ? Unity Container Locator
using System.Configuration; using System.Globalization; using Microsoft.Practices.Unity; using Microsoft.Practices.Unity.Configuration; using Microsoft.Practices.Unity.InterceptionExtension; using System.Web; using System; namespace Common { public static class ServiceLocator { // private static readonly InterfaceInterceptor injector = new InterfaceInterceptor (); private static readonly TransparentProxyInterceptor injector = new TransparentProxyInterceptor(); public static IUnityContainer Container { get; private set; } static ServiceLocator() { Container = new UnityContainer(); UnityConfigurationSection unitySection = ConfigurationManager.GetSection("unity") as UnityConfigurationSection; if (unitySection == null) { throw new ConfigurationErrorsException(string.Format(CultureInfo.CurrentCulture, "missing unity configuration section")); } Container.AddNewExtension<Interception>(); unitySection.Configure(Container, "Container"); } /// <summary> /// 没?有D为a映3射?指?定¨别e名? /// name属?性?没?有D赋3值μ /// </summary> /// <typeparam name="T"></typeparam> /// <returns></returns> public static T LoadService<T>() { Container.Configure<Interception>().SetDefaultInterceptorFor<T>(injector); return Container.Resolve<T>(); } /// <summary> /// 为a映3射?指?定¨别e名? /// name属?性?赋3值μ /// </summary> /// <typeparam name="T"></typeparam> /// <param name="serviceName"></param> /// <returns></returns> public static T LoadService<T>(string serviceName) { Container.Configure<Interception>().SetDefaultInterceptorFor<T>(injector); return Container.Resolve<T>(serviceName); } } }
上层在调用下层的时候,不是调用自己需要的,而是从下层提供的服务中筛选一些可以用的,凑合用一下。如果发现没有自己可以用的,就在IDAL文件中添加一个,然后在DAL文件中实现以下,这下好了,BLL可以用了。这样也会造成在开发DAL层的时候,没有充分考虑BLL的需要,自己盲目实现一些,然后BLL用的时候,才发现很多还要重新写。造成大量的浪费,代码、人力、时间、精力都浪费一部分了。也会影响到开发的进度。
新式分层,抑或叫做DDD分层 |
说是新式分层,其实也是我随便叫的。就是这段时间看了博客园的一些DDD文章,还有就是codeplex上的两个项目NLayerApp和SmartCA的源码。看了这些之后,有的一点理解。不管是神似还是形似吧,反正觉得比以前传统分层有一点道理,就分享出来了,也挣点人气,骗点点击量,哈哈。
先来一张图吧。
DDD中的分层主要是四层:Presentation(表现层),Application(应用层),Domain(领域层),Infrastructure(基础层)。
Presentation相当于以前的UI层。Application是一个任务的调度层,没有实际的业务逻辑,也不推荐放入业务逻辑,实际中可以用Wcf来代替,或者使用普通的类库就可以。其实就是根据UI的业务调用,然后映射到具体的领域对象身上去。也可以通过Application来暴露粗粒度的业务处理,因为领域层的业务处理是细粒度的。没有了以前的DAL,把它的部分放入了Infrastructure层。
以前的IDAL被放入了Domain,在图上,是Domain.Core项目,这个项目会被Infrastructure引用。因为Domain.Core中的IDAL相当于是领域对象对于持久化提出的要求,也就是说必须要实现这些功能,这些都是领域对象需要的。具体的如何实现,具体如何持久化,是持久化到关系数据库还是文件系统,还是内存数据库,都由具体的实现来定义。也就是图中的Infrastructure.Data.Core和Infrastructure.Data.MainModule项目。这两个项目中的实现,实现的都是领域对象持久化所需要的,不会实现一大丢不必要的方法。不知道这算不算是改进呢?
结论 |
传统分层,或者说是我理解的传统分层,存在的问题就是割裂层之间的联系,形式化了层之间的联系。没有表达出上层对于下层的需要,下层是为上层服务的,这些联系。DDD的分层可以解决这个问题,会提高开发的效率,少走一些弯路。
不知道大家是如何认识的呢????????期待大家的回复,拍砖。
转载于:https://www.cnblogs.com/virusswb/archive/2011/01/10/1931964.html
小议传统分层与新式分层,抑或与DDD分层相关推荐
- 适合传统节日促销首焦设计的PSD分层模板
年终岁尾,佳节将至,每逢年末,都是零售商家的销售旺季,而往往在这个节点上,促销成为必要的营销手段. 与一般的促销意义不同,节日根据传统的影响较大,所以更加需要注意节日的各种风俗.礼仪.习惯等民族特点, ...
- DDD分层架构最佳实践
还在单体应用的时候就是分层架构一说,我们用得最多的就是三层架构.而现在已经是微服务时代,在微服务架构模型比较常用的有几个,例如:整洁架构,CQRS(命令查询分离)以及六边形架构.每种架构模型都有自己的 ...
- ddd架构 无法重构_漫谈分层架构:为什么要进行架构分层?
为什么要分层 高内聚:分层的设计可以简化系统设计,让不同的层专注做某一模块的事 低耦合:层与层之间通过接口或API来交互,依赖方不用知道被依赖方的细节 复用:分层之后可以做到很高的复用 扩展性:分层架 ...
- 这 3 种 DDD 分层架构的模式,你掌握了么?
- 前言 - 在讨论DDD分层架构的模式之前,我们先一起回顾一下DDD和分层架构的相关知识. - DDD 的基本概念 - DDD(Domain DrivenDesign, ...
- DDD分层架构的三种模式
本文来说下DDD分层架构的三种模式 文章目录 概述 DDD 分层架构 模式一:四层架构 模式二:五层架构 模式三:六边形架构 本文小结 概述 在讨论DDD分层架构的模式之前,我们先一起回顾一下DDD和 ...
- 应用程序框架实战十八:DDD分层架构之聚合
前面已经介绍了DDD分层架构的实体和值对象,本文将介绍聚合以及与其高度相关的并发主题. 我在之前已经说过,初学者第一步需要将业务逻辑尽量放到实体或值对象中,给实体"充血",这样可以 ...
- 还在搞三层架构?了解下 DDD 分层架构的三种模式吧 !
来源:jianshu.com/p/a775836c7e25 引言 在讨论DDD分层架构的模式之前,我们先一起回顾一下DDD和分层架构的相关知识. DDD DDD(Domain DrivenDesign ...
- 还在搞三层架构?了解下 DDD 分层架构的三种模式吧
引言 在讨论DDD分层架构的模式之前,我们先一起回顾一下DDD和分层架构的相关知识. DDD DDD(Domain Driven Design,领域驱动设计)作为一种软件开发方法,它可以帮助我们设计高 ...
- 什么是DDD分层架构
还在单体应用的时候就是分层架构一说,我们用得最多的就是三层架构.而现在已经是微服务时代,在微服务架构模型比较常用的有几个,例如:整洁架构,CQRS(命令查询分离)以及六边形架构.每种架构模型都有自己的 ...
最新文章
- docker from指令的含义_Docker中Dockerfile多From 指令存在的意义
- C++ map的使用
- 如何使用python批量下载-使用 Python + Selenium 批量下载素材
- dubbo2.5-spring4-mybastis3.2-springmvc4-mongodb3.4-redis3(十)之Spring MVC中使用 Swagger2 构建Restful API...
- jar包名冲突gradle_jar包又冲突了?如何快速确定与哪个jar包冲突?
- el表达式大小写问题的坑坑坑坑坑坑坑坑!!!
- Web IOC 容器初体验
- day10 Python 形参顺序
- 继iptables之后的新一代包过滤框架是nftables
- 关系运算符 与 逻辑运算符
- 实验:基于keepalived实现两台realserver服务器中的nginx和php-fpm服务互为主从
- 剑指offer所有的题目总结(转)
- 归并排序的空间复杂度
- 广色域图片Android,Android Q将支持广色域照片
- Atitit 项目中的勋章体系,,mvp建设 ,荣典体系建设
- fiddler4苹果手机证书无法使用的问题解决方案
- 台式计算机电源机箱维修,终于理会电脑电源故障的维修方法
- 苹果电脑Chrome浏览器截网页长图
- c语言编程三角形面积计算,c语言计算三角形面积代码
- IntelliJ IDEA常用插件介绍和配置
热门文章
- React开发(124):ant design学习指南之form中的属性isFieldTouched
- 前端学习(3153):react-hello-react之脚手架文件介绍
- 前端学习(3131):react-hello-react之总结ref
- 前端学习(3117):react-hello-react的类中的方法
- 前端学习(2971):前一天回顾
- [html] 你写一个页面需要多长时间?
- [css] 你知道css的预处理器和后处理器都有哪些吗?它们有什么区别呢?
- 工作279:控制退回的逻辑修改
- 前端学习(2843):UI插件开发
- 前端学习(2569):如何跨组件调用实例