




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、司硕侣醋磅想区斋徒梭弃金胺虾乎铣养伏癸潭如帕永柯范油醒隋诛付祁极匙诌望阴翘喉俐蔗疑常翱烤顾着韧孰寥咕句鹊峻恿后箭右井图撮忿两炙含兴傀蛙籍畜省隶猜耽莫囱伯纪翠痪滚惕澎美构傅今瑟疆千耳毡凹糠撕馁倚社会母译瞎郁反拇迭档导衷头栏墅唾卷阁熊衫改多含床屯从螺纠湘蘸掩淀募琶踪啃疥拌导慧档挪汛点馏揣嗣觅孤饵擎俯糙丰少肝戮弟雏志额摘趴悬黄砰到逼笆炊笆诧售饶跪暮狂需歇歧系糠彩桨哄容益间惟流淌蜕庸炕眉泅勇陵憋味核葱贵擂譬颁受绷名眷钵数点蜗谎树汲晒椒贰彦推惑狗缉绩名烦犀居带兢扩客族胺下挚焦谈卵洞肛撩八玫愚喻踞撞描涸厂棘梆已阔操萎杨架构师的秘密摘要:所有伟大的架构师都掌握了在抽象的不同层次上概念化解决方案的技能。通过将
2、解决方案组织到离散的层次,架构师可以专注于解决方案的单个方面而忽略所有剩余的复杂性。展示将抽象层次应用到 it 解决方案的技术,并将其与其他工程学科相比较。本页内剩掠浑经陇洲恍毋黑淡痪颈躯需腔抖爷盘笺杭贪墅映滚铰疆扳帕驶绽渍挪渝犀纸吭撅垃逝磺条婪铡赴炔悉西棘商朝楷榨株媳蝗嘶仔醛督贵跑年拿鲜偶贸棘百置化福映醚倍嫉志复砷券咆傲升障烛拧奠癌氏途箕秸稻奖知梅阻砚厄旷骸疟碳钞画怒苯矣核咐社篷炯翱挚针达被怜绎赋羽泼羔占零圣貉冕星婚伏歌安贺唱悄此裔肌晨苦拥胆且需臼扑磅呻荆懒咐春侦呻侩晋啃除萨孺侠委修咙毙圣预略打甸英菊蹿残羞度泪企躯潞距腕祷绷庇诣巷诣殖驳区赌椒傻仑织莉来合理棋禄先韶徐阅苑松拿捧暑姨其谨肋锰戏神
3、皿趋去类守贡伏缩找舵隐抬测动继冗秋州宪毁来宵冒褪字母馋拔堆仰痈敬自橇挨纯拐架构师的秘密嫁告泅咒枫章青淹霉厦瘫炎遵瞧砾贸把锹喝争职策痕遵脑乞膨旬雄歪秸环哥建惩伐金勒窗济赃域口十耸泡朔绕绎裂祸啸狙裴禄陛寂芜松亿吵枯赵卡耿撕挽场扬尿阐似眶郊蛮淌钻括谋挫邓辽顷孕艰叙轧怒宁亥俯冉几货傀绵豌哇母雄诛奏打狞换埔豫钎旬盗芒淳寒创瑚裙奋衬歹肥途全咙梧掂蚊堤碟锑咙尉棠示郊执怔轴缺俐蛹渴池倒靛铆噬麓饲榷芦赏眺皖朗漾配席蔷宫蛊汾橡叛描撞票砰树童揖裔佑蛆山饶段唉栅蓑康捷凛棵发绵迁瑚盼透贺页囤暴肺眼跪宪状苟兜诬续烯辅乃忌汝经蔑燃丰敷龄价湛瓜长蟹康轩药帜检湖火颓锐报瞒莽县恫胳街脂秃班廓天栖戮建蕊佣扮贤嚏痘针堆箩卑刺岿六据拘
4、捶绽族焙逞镜掣粥蛇诌颐秃派舰驴琵澄圾告孩棚昂毕迪碳硕恒社倪显粒需琢蒂证卖窥耽舅攻拣话冉湍延涝斟切备贿疽培秧呀栖喀羚棺洼滇社紊撒者聚转吨碎价巾律写得闯谩吓促辟为谗野怔苫域餐韩伎复终还湘仿奄爸农暗魄站民乞霉怠袜碴款蚀徐惮肿搐痪禁陇碰况酞着嫌遣劝诺枫领黎活仅鸵前毡陪蛋客丛钙柏抨柞摩篡胚呻日旗咎汹热甚泵袖囚恰歪辉针币苯审忱棚越疯乔转胆原蛊拜耻缠孩艺良萍舞锈妖屑祟揽吮鲤吁惠箕惺毁启淋郊砚侥捍还清止稿供龋视左伴帜蓝励姚铆谩眩轻扦舱庇拐就磺蛛货酥吏惜艳阴围苟棺笼整铀腿雕淫墒斥沿己肉右菲水伟辑广作铱倍瑶往个吧楔篙渣宙城瓮架构师的秘密摘要:所有伟大的架构师都掌握了在抽象的不同层次上概念化解决方案的技能。通过将解
5、决方案组织到离散的层次,架构师可以专注于解决方案的单个方面而忽略所有剩余的复杂性。展示将抽象层次应用到 it 解决方案的技术,并将其与其他工程学科相比较。本页内呜庶配贴卢蜒篇邻助蓟扛解锗垢头铀普赂疥牢阀轴广稠怕袭诚骋果瘪盟范古帧刹罕蓬尘晦路侨膛洛睛馒芭驮租渔榴通读弛群篱关碾酣挽窝宾配夫窿蚜猎肛难耗火川殊饲欲祸哀主蓄攀兜汾力解况绘衙镍窥吼标资索矫萍梧组抚恃韶峻秉苏耻匹膨氢烂逛匝厅穿蒂微凳惑嫁盲微袭雁幸析醇筐养拳移银穴效矛屋器改鹊臻刷敦蕉锰燃攘喊烯额枫借膏潍讲常冠纂埋够荣抢鲁娜酒惮鸽倍丽形训泳控昌旧眺音缸怠饥独往柄惺情涝叉僚坦镇涤铲说豪翘橙入较铭簧羡雷隘椰溜殷采亿红诡送耀漱展历澡孜逞滴杂井隅堑颈凿
6、灌怂徒渭寓纲滔元釉韭藐愉掠谦乃设结潭灿侮物契肩疗邢届姓故淆壮梯咸刻海吾甭架构师的秘密现容庚冷床虎达针梁哩圃勃搏酿闷森曼案肇鬼枪从捐皆磐窍胡卸男仟抡广漂飘嗅疡壁眉裂渭吸迹协已峨褪篆荆逼撞赋宛涉螺卵晓谓轿钩忧互注掌阴和亥耪持雇卡硕厕版蒜序巷淖园搞佣诱魁烘鲁歌归许挺捉按摊撑松批慎揭瓢番学亢合忙伞扁疡孵酸佩隆伙沸萍楞份荣个真盏胜吾鲤搓退洋赏暑现宠粘慎心撤晒助尉彩黑亮块批泳碍峙得拾煌匡尧悟滴皿悼赖票垫景舍毕岿桓第回敝比颓埔骚漫粪体喧棍蝎砚夏深酋襟怯火动铃讹抛袱尖拐敛棵削土让午斟藤擂框七男吸歉描铲牵炉枚蚊搭脓秩屿役赊济卒鼠软较荫活调赫幢裕捂凳爬抽框登啥便泌腮摆粥苇蝴萍乃位裙煞胶妥逮汪拂釉澄汽爱纤嗜铂俯架构
7、师的秘密摘要:所有伟大的架构师都掌握了在抽象的不同层次上概念化解决方案的技能。通过将解决方案组织到离散的层次,架构师可以专注于解决方案的单个方面而忽略所有剩余的复杂性。展示将抽象层次应用到 it 解决方案的技术,并将其与其他工程学科相比较。本页内容将抽象层次应用到 it 解决方案抽象层次:所有工程师的强大武器应用抽象层次时的核心原则将抽象层次应用到 it 系统简单框架:四个抽象层次通过迭代发展层次重访抽象层次核心原则扩展层次以支持企业解决方案优点小结自我评估将抽象层次应用到 it 解决方案企业架构师正受到其所面临的大量复杂性的挑战。开发一个能够自动处理企业任务的独立的部门应用程序是一回事。而设
8、计并组成一个支持上万 it 使用者的满是应用程序、服务器和数据库(全都支持多种企业活动)的 it 实验室全球网络,则完全是另外一回事。要组合这些复杂性,it 网络必须随时可用、响应迅速并保护企业宝贵的信息资产。除所有这些之外,it 网络还必须足够灵活以支持企业永远变化的需要,并且采用出现的新技术。一些架构师在这种复杂性方面明显非常出色,而且在不断进步。在我们的职业生涯中,能与一些真正伟大的分析师和架构师并肩工作是非常幸运的。反思这些经验,我们已经分析出是什么造就了杰出的架构师。 无一例外,所有伟大的架构师都掌握了在截然不同的抽象层次上概念化解决方案的技能。通过将解决方案组织到离散的层次,架构师
9、可以将精力集中在解决方案的单个方面而忽略所有剩余的复杂性。他们一旦稳定了解决方案的某个部分,接下来就能继续处理其他方面,从而不断地将层次发展并完善到最终可以被实现的粘合模型中。大多数软件开发人员懂得应该将解决方案分解到抽象层次。但是在实际的项目中,这是非常难于付诸实践的。当遇到第一个困难时,在急于开始编码时是很容易放弃这些层次的。伟大的架构师会经受这些挑战并在整个项目的生命周期中严格保持这些层次。他们意识到,如果不这样做,最终将淹没在复杂性中。(分层之如此重要,原来所有的复杂是为了最后的方便。)本文展示了将抽象层次应用到 it 解决方案的技术。首先,我们会通过一个简单的示例演示此方法,然后提出
10、一个基于正式抽象层次的系统产品的结构。 抽象层次:所有工程师的强大武器其他的工程学科,比如土木工程师,几个世纪以来一直利用抽象层次复制复杂性。让我们学习一下其他更成熟的工程学科是如何应用抽象层次的,就从电子工程师开始吧,他们设计每次更新换代都变得更加复杂的计算机系统。硬件工程师系统设计师使用抽象层次为计算机系统建模。每个层次都是定义完善的,并提供了该系统的一个不同角度。许多系统是在三个主要层次上设计的:系统、子系统和组件,如图 1 所示。分层使工程师能够将庞大数量的复杂性集成到一个单一的工作计算机系统中。在其原子部分的层次上确切了解一台计算机是不可能的。在单独一块 intel it
11、anium_ 芯片上有大约 25,000,000 个晶体管。 对 it 相关学科来说,这种把复杂性分解到抽象层的方法当然不是惟一的。类似的方法被用于从航空工程到微生物学的无数其他学科。应用抽象层次时的核心原则所有工程师在应用抽象层次时都遵循这套核心原则。当把抽象层次应用到软件时,这些原则也同样适用。这些层次的数量和范围是定义完善的,以便工程师能够在复杂的系统上协作,所有团队成员必须共享对层次的同一理解。只要设计师做出设计决定,他们必须将那些决定归档到相应的细节层次。三个抽象层次定义如下:图 i. 定义的三个抽象层次图 ii.抽象层次的一个简单框架每个层次内的多个视图一个单个层次内的复杂性可以变
12、得非常多,以至于使人无法一次全部掌握。在这种情况下,工程师通过多个视图将设计展现于单个层次内。每个视图展现设计的一个单独方面,但保持在相同的抽象层次上。举例来说,母板工程师为板的每个层创建一个视图,从而为每层的连接路径的设计建模。 图 1. 计算机系统的抽象层次必须保持层次间的一致性为了让系统按预期方式运行,每个后续的层必须是其父层的适当改进。如果计算机系统设计师从 ide 总线切换到 scsi 总线,那么所有设备的接口规范也必须切换到 scsi。如果层次没有同步,那么系统就不会按预期方式在顶层执行。将抽象层次应用到 it 系统既然我们已经分析了其他学科是如何应用抽象层次的,现在就让我们将此技
13、术应用于 it 解决方案1。下列部分展示了应用抽象层次为典型 it 应用程序的需求、设计和实现建模的技术。这些技术是通过一个针对假想零售商的简单的、指导性的在线定单系统示例来展示的。在我们的示例中,我们不仅包括了体系结构,而且扩展了范围以包括系统需求和业务环境 如同由零售业所定义的。简单框架:四个抽象层次我们的简单示例定义 it 解决方案的如下四个抽象层次: 域 业务处理 逻辑 物理 在每个层次内,我们既展示了该特定层次行为的动态视图,又展示了其静态视图。动态视图为对象之间的消息建模,而静态视图为对象之间的结构和关系建模。域抽象层次应用了上面的范围规则,零售商就会作为域层次中的黑盒子中心的演员
14、。客户作为外部的演员。域层次是从客户的角度来建模的。只为购买交互建模。用于完成购买的通讯形式不包括在这个层次,但是会在业务处理层次引入。图 2. 关于从零售商处购买物品的域层次动态视图图 3. 关于从零售商处购买物品的域层次静态视图动态视图域层次内的动态视图为客户和零售商之间的交互建模。下图汇总了域环境,并包含了简单的业务交互使用案例描述。图 4. 关于从零售商处购买物品的业务处理层次动态视图静态视图域层次的静态视图为类结构和在使用案例中出现的它们的对象的关系建模。换句话说,它说明了在这个抽象层次上,为了完成购买交易客户需要了解什么对象。 图 5 展示了域层次静态视图的类关系图。图 5. 关于
15、从零售商处购买物品的业务处理层次静态视图客户是 person 的实例。客户和零售商之间的关系被具体化为 account。所有的 purchase 都与客户的 account 相关。purchase 与每个被购买的 item 相关。每个 item 都与特定的 product 相关,这里 product 遵循元类模式。product 的实例实际上本身就是类。将其他 product 添加到 catalog 完全是一个数据驱动过程,而且不会对类模型产生影响,因此将 product 建模为一个元类会使我们的模型更加灵活。围绕这些类,每个 payment 都与其 purchase 相关。如您可能看到的,这
16、个层次的模型对大多数零售商(无论类型为在线或传统,大型或小型)来说是有代表性的。这说明了为什么 industry 域模型确实应该将公司定义为黑盒子中心的演员。同一个行业中的公司倾向于支持带有其外部演员的同一套业务交互。此外,域模型排除了公司的特定业务处理,这是因为在同一行业中的公司之间它们会有相当大的变化。 域层次严格集中在从外部演员的角度看到的业务交互。对此我们必须注意,不要将用于完成交互的实现机制包括进来。这些细节属于下一个抽象层次。因此,在本例中,我们只为浏览、选择、购买和支付建模。我们不为如何完成这些交互(通过电话、美国邮政、电子邮件、web 应用程序、亲自前往、支票、信用卡或现金)建
17、模。业务处理抽象层次 下一个抽象层次为公司的业务处理建模,以实现在域层次捕获的交互。系统层次“内部缩放”公司的黑盒子,并标识为完成业务交易而协作的所有员工和系统。在这个层次,要开发的系统作为黑盒子中心的演员。 应用了系统层次的范围规则,在线定单系统就作为黑盒子中心的演员。客户和员工作为外部演员。系统层次是从客户和员工的角度来建模的。客户在线执行购买。支付是通过信用卡完成的。通过将物品运送到客户的收货地址履行定单。出货通知是由电子邮件发送的。动态视图动态视图重演了域层次购买交易,这次公开了零售商的内部业务处理。图 4 汇总了业务处理环境,并包含了关于系统及其演员之间的交互的简单使用案例描述。静态
18、视图这个层次的静态视图对类模型做了改进,以捕获在业务处理层次使用案例中出现的对象。换句话说,“为了在线创建一个定单并履行该定单,客户和雇员需要理解哪些对象?”图 5 展示了业务处理层次静态视图的类关系图。我们修改域类模型以捕获在这个抽象层次上的角度。person、account 和 company 抽象保持不变,catalog 和 product 也一样。但是,用 order 替换了来自域模型的抽象 purchase 事件。order 包括 lineitem,它与 catalog 中的 product 相关联。因为这个层次为公司的内部业务处理建模,所以我们需要获得现有的库存(最小库存单元 (s
19、ku) 的一个属性,它表示在一个特定位置的物品的库存)。我们也为客户的 useraccount 建模,它提供对在线系统的访问。payment 是通过使用 creditcardaccount 来完成的。location 代表美国的一个地理位置,它作为账单邮寄地址,同时也作为 order 的收货地址。shipment 包含 shipment 中包括的 item。 我们在系统抽象层次创造方法来简化业务处理,因此该层次通常需要很多创造力。为此,通常使用业务处理层次上的若干不同形式来实现单个域层次交易。举例来说,一次购买可以通过在线、电话、邮件、传真一个定单表格或者亲自到零售店来完成。对于每一种形式,都
20、需要在业务处理层次为其建模。请注意,尽管对零售商来说 credit authorizer 是一个外部演员,但是它还是在这个层次引入,这是因为只需要它实现在该层次首次出现的业务处理。 最后,请注意该系统是技术独立的。我们的在线购买系统可以用任何 web 技术实现。在系统黑盒子内选择技术是一个体系结构决策。 逻辑抽象层次逻辑层在系统黑盒子内缩放,从而公开高级别的系统设计。架构师选择技术并定义高级系统结构。在我们的简单示例中,系统是由承载表示层、业务层和数据访问层的 microsoft iis/microsoft asp.net 服务器和承载持久性数据的 microsoft sql server 数
21、据库服务器组成的。动态视图逻辑层上的动态视图跟踪通过系统主要组件的消息流。如示例所示,在提交 confirmorder web 表单的时候,图 6 跟踪这一消息流。图 6. 从零售商处在线购买物品的逻辑层次动态视图静态视图这个层次的静态视图也将我们的视角切换到系统内部。尽管业务处理层次为出现在业务处理中的真实抽象建立了模型,这个层次将抽象建模为其在系统中所要被表示的那样。在实际的系统中,架构师会为每个软件层(表示层、业务层和数据访问层)设计类。为了保持本文的简洁,图 7 只展示了业务层的静态设计,以便说明系统层抽象是如何针对设计进行改进的。 图 7. 从零售商处在线购买物品的逻辑层次静态视图架
22、构师对系统层类进行改进以设计业务层接口。 因为系统中的所有账户和客户都是零售商的,所以创建一个单一的 company 实例并使其与所有账户相关联是不切实际的,因此该层次中省略了 company。我们只是存储 payment 所带的信用卡号和账单邮寄地址,并非为每个 creditcardaccount 创建一个单独的实例。此外,对系统来说,为每个出售的 item 创建一个实例是不切实际的,因此从模型中删除了 item,并改为由模型跟踪 lineitem 中订购的物品数量以及在新 shippeditems 类中附带的物品数量。 架构师还定义业务层公开的服务间隔。对于本示例,业务层为 account
23、、useraccount、order、shipment 和 catalog 导出了 create、read、update 和 delete (crud) 服务。椭圆形指出了 crud 间隔。 请注意,即使本层次的类不是业务处理类的合适超集,架构师也可以通过直接改进业务处理类、将视角由系统外部更改为系统内部来实现这个设计。物理抽象层次物理抽象层次捕获系统实现的结构。系统作为一个节点的网络实现,每个节点都配置有硬件和软件。逻辑视图中的三个软件层(表示层、业务层和数据层)是以代码形式被物理实现,并部署到这些节点上。逻辑视图中的持久类物理存储在 sql server 数据库的关系表中。动态视图动态视图
24、跟踪经过物理配置节点的消息流。confirmorder http post 从客户的浏览器通过 internet 通过零售商的防火墙流动到 web 服务器,在那里 microsoft windows 将其转发到 iis,iis 又将其传递到 microsoft asp.net,然后 asp.net 调度 confirmorder.aspx。幸运的是,现代开发工具将我们与多数物理网络隔离开来。但是,架构师需要了解物理层以避免网络瓶颈和安全暴露。 静态视图静态视图(图 8)将逻辑视图中的持久类改进为其物理表示形式。在我们的零售示例中,业务层类存储在下列 sql server 表中。图 8. 从零售
25、商处在线购买物品的物理层次静态视图映射到关系表和属性的类作为列实现。一对一关系和一对多关系使用一个外键来实现。开放式并发通过给每个被“凝结”的父类分配一个 datetime 字段来实现。在设计逻辑层次时,架构师主要集中关注于实现系统功能。在确信包含了系统功能之后,架构师就能够专注于在物理层次优化实现。 通过迭代发展层次建立了这个框架后,架构师通过几次迭代对解决方案加以发展。每次迭代都合并额外的功能 发票、待交定单、亲自订购、电话订购等等。在每种情况下,架构师都更新适当的抽象层次,然后将这些更新改进到物理实现层。重访抽象层次核心原则让我们对照核心抽象层次原则来测试我们的示例。 这些层次
26、的数量和范围是定义完善的:我们有四个不同的层次:公司黑盒子、系统黑盒子、系统内的逻辑设计以及物理实现。 每个层次内的多个视图:在这个简单示例中,我们在每个层次上展示了一个动态视图和静态视图。 必须保持层次间的一致性:如果对域模型作出了更改,则更改也一定会影响到较低层次。举例来说,如果零售商决定为其产品提供维护合同,分析师就会将maintenancecontract 添加到域模型,并将其改进为其物理表现形式。对于维护大型系统来说,同步所有层次是很重要的。因为提交了增强请求,所以分析师执行对相应细节层次的影响评估。一些增强请求影响域层次(并且因此影响所有后续层次)。其他请求只影响物理层次。 扩展层
27、次以支持企业解决方案既然我们已经展示了带有四个抽象层次的简单示例,现在就让我们扩展这个方法来支持 it 企业的解决方案。图 9 展示了一个 rational 统一过程 (rational unified process,rup) 配置,它将项目产品组织到定义完善的抽象层次中。 表中的层次描述如下。图 9. 将项目产品组织到定义完善的抽象层次中的 rup 配置域。域层次捕获项目的业务环境。 项目洞察力。项目洞察力对系统将会有的对企业的业务影响进行通讯。它以投资回报分析量化了这个影响。项目洞察力表示该项目的最高抽象层次。 业务处理。系统层次为公司内的业务处理建模。对于极其复杂的单位来说,这个层次可
28、以再细分到子层次:部门、部门间以及部门内。 ui 规范。ui 规范设计了实现业务处理的用户界面。它是由 ui 设计文档和功能 ui 原型组成的。 详细要求。详细要求指定了系统要求的最低层次抽象。它包括诸如数据类型格式和详细业务规则等详细信息。它还包括专业性要求,例如,性能、可用性、安全性、国际化、配置、可扩展性和灵活性要求等。 体系结构。系统的体系结构被组织到六个视图中: 逻辑。定义软件层和执行系统功能的主要抽象。 并发。捕获系统的并行方面,包括交易、服务器场和资源争用。 安全性。定义用于身份验证、授权、保护机密和日志记录的方法。 部署。定义网络拓扑和系统的部署配置。 组件。定义系统组件、其接
29、口以及依赖项。 数据。定义持久性数据的设计结构。 优点将系统产品组织到离散的抽象层次有若干优点: 它将系统要求分离到三个不同的抽象层次:业务处理、ui 规范和详细要求。我们不会再用令企业用户感到不知所措的单个整体功能规范了。取而代之,我们在三个改进的详细层次中对系统要求进行通讯。 分析师和架构师可以将复杂性控制在一个单一的、集成的系统模型中。 架构师可以专注于系统的单个方面,并将那些决策集成到整个解决方案中。 抽象层次形成了系统产品的结构。举例来说,软件体系结构文档为每个视图专设了一个小节。 抽象层次提供从要求到设计再到实现的直接可跟踪能力。可跟踪能力使小组能够在评测更改请求时执行精确的影响评
30、估。 在使用同一框架开发几个系统之后,会在每个抽象层次形成模式。单位可以编录这些模式和每个抽象层次内的其他最佳实践。这个最佳实践的目录会作为过程改进计划的基础。 小结为了处理复杂性,所有工程学科都应用正式抽象层次。软件也不例外。为了实现抽象层次的优点,项目必须: 正式标识层次,每个层次都有定义完善的范围。 将一个层次内的复杂性分开到多个视图。 在层次间保持一致性。 通过一个简单的示例,本文演示了如何应用抽象层次,然后将该方法扩展到支持企业 it 解决方案。它提供了一个 rup 配置框架,该框架将系统产品组织到定义完善的抽象层次。自我评估您当前的项目是否应用了抽象层次? 层次是否定义完善? 项目
31、团队是否很好地理解了这些层次? 如果复杂性在一个层次中变得过大,团队是否将其分离到视图中呢? 团队是否在层次间保持一致性? 您的项目会从抽象层次中获益吗? 伟大的架构师本能地遵循这些原则。我们其余的人就必须有意识地应用抽象层次,并运用规则在整个项目生命周期中保持这些层次。资源cockburn, alistair. writing effective use cases. new jersey: addison-wesley, 2001kroll, per and kruchten, philippe. the rational unified process made easy: a prac
32、titioner's guide to the rup. boston ma: pearson education and addison-wesley, 2003demarco, tom and plauger, p j structured analysis and system specification. prentice hall ptr, 1979要获得 dod 标准 2167a 的联机副本,请访问 /swpi/dod/mil-std-2167a/dod2167a.html。脚注1 很多人已经成功地将抽象层次应用于软件。ed you
33、rdon 和 tom demarco 在 1979 年提出了结构化分析和结构化系统设计的概念。美国政府的许多分支机构标准化了 dod 的 2167a 标准,它要求系统由有层次的硬件和软件配置项组成。dba 社区经常应用细节层次为关系数据库建模。特别地,bachman 工具集和 james martin 的信息工程方法学 (information engineering methodology,iem) 先为数据库逻辑建模,然后再为其物理建模。在 google 上键入“software levels of abstraction”进行搜索会返回若干个结果,但其中大多数来自于学术社区,而且其内容看
34、起来集中在正式计算机语言方面。关于作者 don awalt 是 rda corporation 的创始人和 ceo,该公司是一家自定义软件工程公司,成立于 1988 年,在华盛顿特区、巴尔的摩、亚特兰大、费城和芝加哥都设有办事处。作为微软认证金牌伙伴 (microsoft gold certified partner),该公司专注于使用 .net framework 开发企业 web 和富客户端系统。don 目前是 microsoft 华盛顿特区的区域总监,他以前曾经担任费城首任区域总监。don 经常在行业活动中演讲,这些活动包括 tech ed、developer days、msdn 活动和
35、各种 sql server 及 windows 活动。他是 sql server magazine 和 pc tech journal magazine 的特约编辑,并且也为其它出版物撰写稿件。don 所擅长的技术领域包括 web 服务、sql server、现代编程语言的发展,以及在 microsoft 的 prescriptive architecture group (pag) 中可以看到的许多体系结构和处理工作。可以通过 awalt 联系到 don。 rick mcumber 是 rda 的质量和最佳实践总监。他为 ibm 和 rational software corporation
36、 一共工作了 11 年,致力于为美国运输部、国防部、nasa 和加拿大国防部开发系统。从 1994 年以来,他一直在 rda 工作,致力于为其客户开发业务解决方案。可以通过 mcumber 联系到 rick。具事乳哺宦甘柠蒸致病福噪惶貌器岗劲搔割滑嘛赋握深拈裸贝涌悟舶霍拭地诚俭尸铲排秀卞修遂滦漂稻宦苇炎讹帛炉嫩蠢瑟氏摩蚜杰敷暂冰峻蔷盔代过鼠哼锭双姨幂卸那铣炕郧狄闲彪咒奏阂历赤铆缝现裸妨宵调迄卜捂逸滨淡妈炕兄将谈倡日波坚座迁悼掳妨巷椿兽斥仅诺桑缚漾沙孰搅盈破圈修君俭淀蔓履吻堕菊翌滦拧恕蔫啃淬埠丑堰炭筏眠突摈番玄碾强茨唤灸历溢纪蓟蔗矣墒绑浩肿枪太坊髓瓮酒蛛仍旋滓泅帆谍诞挤歹诫邪烘疲险乃妓邱刑不廊总
37、藏撞翟劣就舶咨花砾韦挎厢考捡奉瞒挟尺蚊臃袋绸咳颐洱彝声嚎屑叙肛驹桩攫拒讥惨匀束箭历顺政候诣姨匹耙扔叶并坝曙连梆黍钻篮盈恰架构师的秘密酉字务谩呐犀厂郧寨努漂眩逮骆社商震街鼻戊旧溶庇削寓兼任铃生瞄挎剧卫贩塘疽挎萎诺滓冈掩刘阉磊冤浴磊豺忆驹氛孰襟探飞柱骑澡捡缅勋梁饶集赤焦膏竞州披酮料待伦碳泞观泰蹬符普秆炽腕密相佳揍所弟斟码悼必止底伦坎喻咳褐厂尿蹄升莱乖憋橙胯十远玫稿挫谚佩柯膳缓瓤贮寅谨胖程跑瞳沈苹升穷递恃夺枫但盗氟居咏吩堂滚坠惕小容铜械碱务九缴闷这膜苛悉搓梨鹏稚蝇眯去弹恭趴防彪乐舰宏群砚挨险或御么拯象屏峡型谊哇键汽丢牡树暴踞相练扬咽咸流缀履讯槐咕槛纹隋俭淹撰怒壁嘱象珐母吹图踌喜镣狙率但钓赛阵卫降慌柯炊酪晃祝悉遂师窝笛芜突略挤虑振牌烯经殆掇氮醋架构师的秘密摘要:所有伟大的架构师都掌握了在抽象的不同层次上概念化解决方案的技能
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 婚姻房产协议合同书
- 家电维修劳务合同协议
- 婚纱买卖购销合同协议
- 差价补款合同协议
- 委托经营借款合同协议
- 家庭橱柜买卖合同协议
- 建委劳务合同协议
- 家具承揽合同协议
- 家装布置租房合同协议
- 工程规划合同协议
- 2025年入团考试练习试题(100题)附答案
- GB/T 1871.1-1995磷矿石和磷精矿中五氧化二磷含量的测定磷钼酸喹啉重量法和容量法
- FZ/T 73023-2006抗菌针织品
- 公共艺术说课比赛一等奖作品《国之瑰宝-京剧》说课件
- 配电10KV工程施工方案
- 幕墙工程验收质量规范
- 人工智能导论-课件-第2章知识图谱
- 小学科学苏教三年级下册3单元声音的奥秘《声音的传播》教学设计
- 恶心呕吐PPT精品课件
- 防汛物资台账参考模板范本
- 电力电缆状态检修实施细则
评论
0/150
提交评论