基本信息
- 商品名:面向模式的软件架构卷4:分布式计算的模式语言
- ISBN:9787115227737
- 定价:69.00
- 出版社:人民邮电出版社
- 作者:布施曼
参考信息(以实物为准)
- 出版日期:2010-06-01
-
- 版次:1
- 包装:
- 开本:大16开
- 用纸:胶版纸
- 页数:348
- 字数:538
内容提要
《面向模式的软件架构:分布式计算的模式语言(卷4)》关注分布式计算软件的设计和实现。书中首先介绍理解《面向模式的软件架构:分布式计算的模式语言(卷4)》内容所需的核心的模式概念,分布式计算的好处和挑战;然后描述如何使用分布式计算模式语言,设计真实世界中仓库管理流程控制;后重点讲述分布式计算模式语言,该语言陈述了创建分布式相关的技术主题。
《面向模式的软件架构:分布式计算的模式语言(卷4)》适用于软件架构师和开发人员。
目录
部分 概念
第1章 模式与模式语言2
1.1 模式2
1.2 模式内幕3
1.2.1 问题的环境3
1.2.2 驱动因素:所有模式的核心4
1.2.3 解决方案与结果4
1.2.4 模式命名4
1.2.5 模式表现形式概述5
1.3 模式的关系5
1.3.1 模式的互补5
1.3.2 模式的组合6
1.3.3 模式故事6
1.3.4 模式序列7
1.4 模式语言7
1.4.1 从模式序列到模式语言7
1.4.2 展现和使用模式语言7
1.5 模式的连接8
第2章 分布式9
2.1 分布式的优点9
2.2 分布式的挑战11
2.3 用以支持分布式的技术12
2.3.1 分布式对象计算中间件13
2.3.2 组件中间件14
2.3.3 发布/订阅中间件和面向消息的中间件15
2.3.4 面向服务架构和Web服务16
2.4 中间件技术的局限性17
第3章 模式语言18
3.1 意图、范畴和对象18
3.2 起源18
3.3 结构和内容19
3.4 模式的表现24
3.5 实际应用26
第二部分 模式故事
第4章 仓库管理流程控制33
4.1 范畴33
4.2 仓库管理流程控制34
第5章 基线架构37
5.1 架构环境37
5.2 划分大泥球38
5.3 层次分解38
5.4 访问领域对象功能40
5.5 网络桥接41
5.6 分离用户界面43
5.7 功能分布45
5.8 支持并发的领域对象访问47
5.9 获得可扩展的并发性48
5.10 将面向对象与关系型数据库连接起来49
5.11 领域对象的运行时配置50
5.12 基线架构结51
第6章 通信中间件54
6.1 分布式的中间件架构54
6.2 对中间件的内部设计进行结构化57
6.3 封装底层机制58
6.4 分离ORB核心事件59
6.5 ORB连接管理61
6.6 提高ORB的可伸缩性63
6.7 实现同步请求队列65
6.8 可互换的内部ORB机制66
6.9 管理ORB策略68
6.10 ORB动态配置69
6.11 通信中间件结71
第7章 仓库拓扑74
7.1 仓库拓扑基线74
7.2 表现层次化的存储结构74
7.3 存储结构导航77
7.4 存储属性建模78
7.5 不同的存储单元行为79
7.6 实现全局功能81
7.7 遍历仓库拓扑81
7.8 支持控制流扩展83
7.9 连接数据库84
7.10 维护内存中的存储单元数据85
7.11 配置仓库拓扑86
7.12 细述显式接口88
7.13 仓库拓扑结89
第8章 模式故事背后的故事91
第三部分 模式语言
第9章 从混沌到结构97
9.1 DomainModel**106
9.2 Layers**108
9.3 Model-View-Controller**109
9.4 Presentation-Abstraction-Control111
9.5 Microkernel**113
9.6 Reflection*114
9.7 PipesandFilters**116
9.8 SharedRepository**117
9.9 Blackboard119
9.10 DomainObject**121
第10章 分布式基础设施123
10.1 Messaging**129
10.2 MessageChannel**130
10.3 MessageEndpoint**132
10.4 MessageTranslator**133
10.5 MessageRouter**134
10.6 Publisher-Subscriber**135
10.7 Broker**137
10.8 ClientProxy**139
10.9 Requestor**140
10.10 Invoker**142
10.11 ClientRequestHandler**143
10.12 ServerRequestHandler**144
第11章 事件分离和分发147
11.1 Reactor**150
11.2 Proactor*152
11.3 Acceptor-Connector**154
11.4 AsynchronousCompletionToken**155
第12章 接口划分157
12.1 ExplicitInterface**163
12.2 ExtensionInterface**165
12.3 IntrospectiveInterface**166
12.4 DynamicInvocationInterface*167
12.5 Proxy**169
12.6 BusinessDelegate**170
12.7 Facade**171
12.8 CombinedMethod**172
12.9 Iterator**173
12.10 EnumerationMethond**174
12.11 BatchMethod**175
第13章 组件划分177
13.1 EncapsulatedImplementation**181
13.2 Whole-Part**183
13.3 Composite**185
13.4 Master-Slave**186
13.5 Half-ObjectplusProtocol**188
13.6 ReplicatedComponentGroup**189
第14章 应用控制191
14.1 PageController**196
14.2 FrontController**197
14.3 ApplicationController**198
14.4 CommandProcessor**199
14.5 TemplateView**200
14.6 TransformView**201
14.7 FirewallProxy**202
14.8 Authorization**204
第15章 并发206
15.1 Half-Sync/Half-Async**209
15.2 Leader/Followers**211
15.3 ActiveObject**212
15.4 MonitorObject**214
第16章 同步216
16.1 GuardedSuspension**221
16.2 Future**223
16.3 Thread-SafeInterface*224
16.4 Double-CheckedLocking225
16.5 StrategizedLocking**226
16.6 ScopedLocking**227
16.7 Thread-SpecificStorage228
16.8 CopiedValue**230
16.9 ImmutableValue**231
第17章 对象间的交互233
17.1 Observer**237
17.2 DoubleDispatch**238
17.3 Mediator*239
17.4 Command**240
17.5 Memento**242
17.6 ContextObject**243
17.7 DataTransferObject**244
17.8 Message**245
第18章 适配与扩展247
18.1 Bridge**255
18.2 ObjectAdapter**256
18.3 ChainofResponsibility*257
18.4 Interpreter258
18.5 Interceptor**260
18.6 Visitor**261
18.7 Decorator262
18.8 Execute-AroundObject**264
18.9 TemplateMethod*265
18.10 Strategy**266
18.11 NullObject**267
18.12 WrapperFacade**269
18.13 DeclarativeComponentConfiguration*270
第19章 模态行为272
19.1 ObjectsforStates*274
19.2 MethodsforStates*275
19.3 CollectionsforStates*276
第20章 资源管理278
20.1 Container*288
20.2 ComponentConfigurator*289
20.3 ObjectManager**291
20.4 Lookup**292
20.5 VirtualProxy**294
20.6 LifecycleCallback**295
20.7 TaskCoordinator*296
20.8 ResourcePool**298
20.9 ResourceCache**299
20.10 LazyAcquisition**300
20.11 EagerAcquisition**301
20.12 PartialAcquisition*303
20.13 Activator**304
20.14 Evictor**305
20.15 Leasing**306
20.16 AutomatedGarbageCollection**307
20.17 CountingHandles**309
20.18 AbstractFactory**311
20.19 Builder*312
20.20 FactoryMethod**313
20.21 DisposalMethod**314
第21章 数据库访问316
21.1 DatabaseAccessLayer**318
21.2 DataMapper**320
21.3 RowDataGateway**321
21.4 TableDataGateway**323
21.5 ActiveRecord324
第22章 后的思考326
术语表327
参考书目340
作者介绍
布施曼(FrankBuschmann),是德国慕尼黑西门子公司部技术部门的工程师。他的研究兴趣包括对象技术、软件体系结构、框架和模式。他在这些领域发表了很多文章,这些文章可以在他与人合著的POSA第1卷中找到。Frank于1992~1996年期间是ANSIC++标准化委员会X3J16的成员。Frank发起并组织了在欧洲举办的次关于模式的会议——EuroOLop1996,他也是PLoPD丛书第三卷的主编之一。Frank参与了一些大规模工业软件项目的设计与实现,这些项目包括商务信息、工业自动化以及电信。
工作之余,Frank的生活丰富多彩。他喜欢陪着妻子Martina和女儿Anna享受家庭的快乐;他喜欢骑着马儿Eddi外出遛弯,或者独自跑到慕尼黑啤酒花园打发时间;他喜欢在观看爱的多特蒙德足球队的比赛时尽洒激情,也偶尔在慕尼黑歌剧院里的演出中尽情陶醉;临睡前他还喜欢来杯珍藏的苏格兰纯麦威士忌。
亨尼(KevlinHenney),住在英国布里斯托尔,是一名独立顾问。他主要从事自己感兴趣的领域的教授、辅导和实践,这些领域包括编程语言和技术、软件架构、模式和敏捷开发。他的客户既有化的公司,也有刚起步的小公司,所涉及的领域包括软件、电信、嵌入式、中间件开发、业务信息和金融。
Kevlin经常在各种软件会议上应邀演讲,同时也参与了多个会议的组织工作,包括EuroPLoP。他通过英国标准学会(BSI)和ISO参与到c++的标准中来,同时也参与了其他语言的标准化工作。Kevlin也因其写作受人关注,经常发表会议论文,主持各种出版物上定期的(和不定期的)专栏,比如Cl++Report、Cl/c++己lsersJournal.JavaReporT、JavasPektrum、ApplicationDevelopmentAdvisor、TheRegister、EXE和Overload。
Kevlin的业余时间则是与妻子Carolyn还有两个孩子Stefan和Yannick度过的。他跟孩子摆摆积木,给孩子们修修玩具,看书,有时也啜几口啤酒或者来一杯葡萄酒。
施密特(DougSchmidt),是美国田纳西州纳什维尔市范德比尔特大学计算机科学教授,计算机科学与工程计划副。他的研究领域包括模式和模式语言、优化原理,还包括对于支持服务质量(QoS)的组件中间件相关技术的实证分析(empiricalanalysis)和支持分布式实时嵌入式的模型驱动的工程工具。
Doug是公认的软件开发方面的专家,尤其是模式、面向对象框架、实时中间件、建模工具和开源软件开发等方面。他已经在各种技术杂志和会议上发表了300多篇论文;他与人合著了模式方面的著作[POSA2]和有关C++网络编程的[SH02][SH03];同时他还与人合编过数本的书,比如模式方面有[PLoPDl],框架方面有[FJS99a][FJS99b]。除了学术研究,Doug还了ACE、TAO、CIAO和CoSMIC的开发,这些广泛应用的开源的中间件框架和模型驱动的工程工具包含了一整套丰富的可重用的组件,这些组件的实现大量使用了本书中介绍的模式。
在他闲暇之隙,Doug是跟妻子Lori和儿子Bronson待在一起,他们一起练练举重、弹弹吉它、讨论世界历史和政治,或者开着他们的雪佛兰Corvette跑车四处兜风。
译者简介:
肖鹏,ThoughtWorks咨询师。敏捷过程教练。面向对象分析和面向对象设计专家。拥有6年以上软件开发实践经验,多次担任国内大中型企业敏捷流程改进、面向对象分析和面向对象设计咨询和培训。他长期关注设计模式、架构模式、敏捷软件开发等领域。并致力于推广软件开发佳实践。他曾参与翻译《ViSualStudio2005技术大全》,主持翻译《面向模式的软件架构》第四卷和第五卷。
序言
