petshop4.0 详解之一(系统架构设计)
前言:PetShop 是一个范例,微软用它来展示.Net 企业系统开发的能力.业界有许多.Net 与 J2EE 之争,许多数据是从微软的 PetShop 和 Sun 的 PetStore 而来.这种争论不可避免带有 浓厚的商业色彩,对于我们开发人员而言,没有必要过多关注.然而 PetShop 随着版本的不断 更新,至现在基于.Net 2.0 的 PetShop4.0 为止,整个设计逐渐变得成熟而优雅,却又很多可 以借鉴之处.PetShop 是一个小型的项目,系统架构与代码都比较简单,却也凸现了许多颇有 价值的设计与开发理念.本系列试图对 PetShop 作一个全方位的解剖,依据的代码是 PetShop4.0,可以从链接 http://msdn.microsoft.com/library/default.asp url=/library/en-us/dnbda/html/bd asamppet4.asp 中获得. 一,PetShop 的系统架构设计 在软件体系架构设计中,分层式结构是最常见,也是最重要的一种结构.微软推荐的分层式结构 一般分为三层,从下至上分别为:数据访问层,业务逻辑层(又或成为领域层),表示层,如图 所示:
图一:三层的分层式结构 数据访问层:有时候也称为是持久层,其功能主要是负责数据库的访问.简单的说法就是实现对 数据表的 Select,Insert,Update,Delete 的操作.如果要加入 ORM 的元素,那么就会包 括对象和数据表之间的 mapping,以及对象实体的持久化.在 PetShop 的数据访问层中,并 没有使用 ORM,从而导致了代码量的增加,可以看作是整个设计实现中的一大败笔.
业务逻辑层:是整个系统的核心,它与这个系统的业务(领域)有关.以 PetShop 为例,业务 逻辑层的相关设计,均和网上宠物店特有的逻辑相关,例如查询宠物,下订单,添加宠物到购物 车等等.如果涉及到数据库的访问,则调用数据访问层. 表示层:是系统的 UI 部分,负责使用者与整个系统的交互.在这一层中,理想的状态是不应包 括系统的业务逻辑. 表示层中的逻辑代码, 仅与界面元素有关. PetShop 中, 在 是利用 ASP.Net 来设计的,因此包含了许多 Web 控件和相关逻辑. 分层式结构究竟其优势何在 Martin Fowler 在《Patterns of Enterprise Application Architecture》一书中给出了答案: 1,开发人员可以只关注整个结构中的其中某一层; 2,可以很容易的用新的实现来替换原有层次的实现; 3,可以降低层与层之间的依赖; 4,有利于标准化; 5,利于各层逻辑的复用. 概括来说,分层式设计可以达至如下目的:分散关注,松散耦合,逻辑复用,标准定义. 一个好的分层式结构,可以使得开发人员的分工更加明确.一旦定义好各层次之间的接口,负责 不同逻辑设计的开发人员就可以分散关注,齐头并进.例如 UI 人员只需考虑用户界面的体验与 操作, 领域的设计人员可以仅关注业务逻辑的设计, 而数据库设计人员也不必为繁琐的用户交互 而头疼了.每个开发人员的任务得到了确认,开发进度就可以迅速的提高. 松散耦合的好处是显而易见的.如果一个系统没有分层,那么各自的逻辑都紧紧纠缠在一起,彼 此间相互依赖, 谁都是不可替换的. 一旦发生改变, 则牵一发而动全身, 对项目的影响极为严重. 降低层与层间的依赖性,既可以良好地保证未来的可扩展,在复用性上也是优势明显.每个功能 模块一旦定义好统一的接口,就可以被各个模块所调用,而不用为相同的功能进行重复地开发. 进行好的分层式结构设计,标准也是必不可少的.只有在一定程度的标准化基础上,这个系统才 是可扩展的,可替换的.而层与层之间的通信也必然保证了接口的标准化. "金无足赤,人无完人",分层式结构也不可避免具有一些缺陷: 1,降低了系统的性能.这是不言而喻的.如果不采用分层式结构,很多业务可以直接造访数据 库,以此获取相应的数据,如今却必须通过中间层来完成. 2,有时会导致级联的修改.这种修改尤其体现在自上而下的方向.如果在表示层中需要增加一 个功能, 为保证其设计符合分层式结构, 可能需要在相应的业务逻辑层和数据访问层中都增加相 应的代码. 前面提到,PetShop 的表示层是用 ASP.Net 设计的,也就是说,它应是一个 BS 系统.在.Net 中,标准的 BS 分层式结构如下图所示:
图二:.Net 中标准的 BS 分层式结构 随着 PetShop 版本的更新,其分层式结构也在不断的完善,例如 PetShop2.0,就没有采用标 准的三层式结构,如图三:
- 电子商务设计师pdf > 详解之一(系统架构设计)
-
详解之一(系统架构设计)
下载该文档 文档格式:PDF 更新时间:2008-05-02 下载次数:0 点击次数:2文档基本属性 文档语言: Simplified Chinese 文档格式: pdf 文档作者: YlmF 关键词: 主题: 备注: 点击这里显示更多文档属性 经理: 单位: WwW.YlmF.CoM 分类: 创建时间: 上次保存者: 修订次数: 编辑时间: 文档创建者: 修订: 加密标识: 幻灯片: 段落数: 字节数: 备注: 演示格式: 上次保存时间:
- 下载地址 (推荐使用迅雷下载地址,速度快,支持断点续传)
- PDF格式下载
- 更多文档...
-
上一篇:国际物流及流通管理学分学程
下一篇:年3 月30
点击查看更多关于电子商务设计师pdf的相关文档
- 您可能感兴趣的
- 电子商务设计师pdf 电子商务.pdf 软装设计师手册pdf 软件设计师教程pdf 形象设计师pdf bct商务韩语考试pdf 商务英语mail写作pdf pdf格式电子杂志下载 肿瘤学电子pdf课本
- 大家在找
-
- · 挖掘机价格
- · 第15届香港金像奖
- · 2012年政法干警报名
- · cimatron12.6论坛
- · 单片机原理及应用教程
- · plc正反转
- · 厦门大学考研专业目录
- · 电力拖动控制线路
- · 乌鲁木齐汽车租赁价格
- · 如何运用脚注和尾注
- · win7pads2007安装
- · 农电工招工
- · 博世喷油器工作视频
- · 焊工工艺学教案
- · 细胞器结构图
- · qq2011官方安装
- · 北京丰田4s店地址电话
- · 三本院校专业排名
- · 上海诺泰化工有限公司
- · cad侠免费模型下载
- · 幼儿园教育随笔
- · 北京五十挂帐村农转居
- · mathtype破解版
- · 乌鲁木齐市第十三小学
- · 江西理工大学统计学试卷
- · 潮汕夏雨来
- · 牛津小学英语6aunit5
- · 商务礼仪ppt免费下载
- · 北京房价多少钱一平米
- · 普宁流沙招聘
- 赞助商链接