阿里、蚂蚁、晟腾、中科加禾精彩分享 AI 基础设施洞见,现购票可享受 9 折优惠 |AICon 了解详情
写点什么

面向模式软件架构第 4、5 卷出版

  • 2007-08-24
  • 本文字数:1843 字

    阅读完需:约 6 分钟

面向模式软件架构(POSA)系列的第4 卷第5 卷已经出版了。卷4 是关于分布式计算的模式语言,而卷5 则“深入审视模式是什么,不是什么,以及怎样成功地使用它们”。

InfoQ 采访了最新卷的合著者之一 Kevlin Henney ,讨论了 POSA 系列的最新两本书。我们询问 Kevlin:两本书怎么会几乎同时出版?

最初的打算是只有一本书,其内容按照 POSA 5 的想法来组织。这个想法是,介绍书写和组织模式的概念、原则及技巧,我们通过一个大的例子来说明:用于分布式计算的模式语言,并附带一个模式故事(pattern story),在实践中说明它的应用。

正如你猜到的,这将会是一部非常厚的书!

POSA4 是关于分布式系统的——该书关注哪些类型的分布式系统呢?

……我们试图编写那些可在经典的 RPC 风格系统、当代的 Web 应用、基于消息的系统、经典的 N 层系统、移动计算等系统中找得到的范围广泛的架构概念。我们特别关注于那些已被实践证明的架构和架构知识……我们覆盖了应用和中间件架构,并对新系统开发及现有系统的后续开发都有兴趣。

本书的风格不同于前几卷。POSA4 描述了 114 个模式,而前 3 卷总共才包含了 44 个模式。前几卷对每个模式进行了深入地探讨,但是因为 POSA4 的大多数模式已在其它著作中发表,因此模式的细节不再作为重点,取而代之的是模式间的关系。

相比之下,POSA4 意图给架构师和开发者提供的一个更广的、宏观的模式视图,这些模式涉及到当代分布式计算架构中应用的模式。重点是模式是如何关联的,其中包括一个模式实现另一个的细节或为另一个提供替代选择,因此这意味着联系才是重点,从而减少了每个模式的细节。

然而,更少的细节并不必然意味着令每个模式的核心概念变得失真:

模式并不会因为本身的简洁而变得不精确——在某些情形下,它们的描述还更准确了–而是它们被概括并忽略了很多不必要的细节。

为了保持每个模式描述的简洁,本书使用草图和伪代码代替了 UML 图和完整的 C++ 或 Java 例程。对于想深入了解特定模式的读者,它提供了参考。

我们询问 Kevlin:他是否觉得有一些特殊的模式被遗忘或被误解了,而它们对于能出现在本书中将会感到非常高兴?

有些模式是非常的不引人注目,但是它们在现代设计方法中具有某种重要且非常有影响的地位。

首先一个,我们称之为显式接口(Explicit Interface),它本质上是一个分离单独接口的概念,将它完全从它的实现中解耦。这种方法适合声明类型系统并自从 RPC 时代就存在,而且我们发现它在现代静态类型语言中非常普遍,即‘接口(interface)’结构。然而,显式接口模式的关键点是设计敏感度,其背后使用了某种机制并聚焦于关注点的分离。不顾近些年来基于接口的编程的增多,许多程序员仍然使用纯接口(不论是以“接口”结构的形式,还是按照全抽象类的方式),以一种更多不必要的耦合方式,如果这也算面向接口编程的话。

第二个是关于上下文对象(Context Object)。和接口的想法类似,上下文对象的想法已经存在很长时间了(它现身于 Scheme 的 eval 过程中,并可在四人帮的解释器(Interpreter)模式中找到踪迹),但它最近才被记录并陈诉其有权作为模式的理由。POSA4 中的详细描写只是许多不同的详细说明(其中有我的一个,另一个则是 Doug 的!)中最新的一个。上下文对象可以使用执行细节(如配置、证书、查找服务等)参数化一个对象、组件或整个子系统,使之独立于系统的其它部分。这种分离提高了组件间的独立性,简化了测试,排除了一类问题,以及 / 或在多线程环境中可能遇到的执行瓶颈。它常常被视为使用 Singleton 之后带来的许多问题的解毒剂(并且,作为题外话,Singleton 是我们没有包含在本书中的一个模式:->)。

第 5 卷也是本系列的最后一卷书,是关于模式和模式语言。它显示了如何记录、组织和使用模式;如何建立模式间的关系,以及如何将这种关系转变成模式语言。

在 POSA5 之前,模式的概念性讨论分散在模式社区内外的许多著作和不同人的脑袋中。那些展示了模式集合的每一本书、论文或展示都使用不同观点介绍了模式概念,它们之间或多或少的有些不同。不同的来源侧重不同的方面的不同重点,例如模式发生的上下文、模式语言的使用、模式中的各种驱动力的角色,模式的社会或技术目标等等。

Kevlin 总结说:

POSA5 [……] 是写给那些有兴趣进一步探索模式概念的实践者的。换句话说,这本书的目标读者是,那些已经以某种形式接触过模式——不论是通过 GoF、POSA、Core J2EE,还是通过其他方式——并想更多了解模式的人。

查看英文原文: Pattern Oriented Software Architecture Volumes 4 and 5 released

2007-08-24 05:112766
用户头像

发布了 255 篇内容, 共 54.4 次阅读, 收获喜欢 9 次。

关注

评论

发布
暂无评论
发现更多内容

ARTS薪火重启之第一周

渣渣辉

算法 职业规划 心得分享

盘古开天、AI落地,走进华为看AI如何重塑千行百业

彭飞

“这对我个人能力的认可意义重大”!数据库“小白”到 Apache IoTDB committer 的心路历程!

Apache IoTDB

揭穿DevOps的5个谣言!

互联网工科生

DevOps 运维 自动化运维

文档比对技术难点与使用场景

合合技术团队

人工智能 算法 文字识别 文档对比

【学习课程送福利!】InfoQ最新Java开发课程喊你来领奖品!100%中奖!

SoFlu软件机器人

腾讯云ES:一键配置,LDAP身份验证服务来了!

腾讯云大数据

ES

LeetCode题解:617. 合并二叉树,JavaScript,详细注释

Lee Chen

JavaScript LeetCode

Python 运行 shell 命令的一些方法

互联网工科生

Python Shell Shell命令

生成式AI崛起,元宇宙发展遭遇挑战

百度开发者中心

元宇宙 文心一言

生成式AI:数字医疗前瞻的新引擎

百度开发者中心

医疗 百度文心一言

华为开发者大会2023:云空间筑牢鸿蒙生态“云基因”

HMS Core

HarmonyOS

达芬奇DaVinci Resolve Studio 18 for mac(视频调色软件) v18.5.1正式激活版

mac

苹果mac Windows软件 DaVinci Resolve Studio 专业视频剪辑软件

用低代码实现企业敏捷运营

力软低代码开发平台

Waves 14 Complete for Mac(后期混音效果全套插件)v2023.08.09激活版

mac

苹果mac Windows软件 Waves 14 Complete 后期混音效果全套插件

上央视啦!扫描全能王科技助力社会跑步进入无纸化办公时代

合合技术团队

人工智能 环保 无纸化办公

使用K8s的一些经验和体会

这我可不懂

Java Kubernetes 运维

首起针对国内金融企业的开源组件投毒攻击事件

墨菲安全

网络安全 安全 投毒分析

生成式AI:引领我们进入零信任世界

百度开发者中心

文心一言

生成式AI在金融行业的创新应用

百度开发者中心

金融 文心大模型

如何仅用几分钟就能破解8个字符长的密码?

高端章鱼哥

黑客 密码安全 破译密码

生成式AI产业趋势:技术升级与广泛应用

百度开发者中心

百度文心一言 文心大模型

如何唤醒潜在用户?选择智能化推送系统的重要性

MobTech袤博科技

前端 前端开发 APP开发 前端开发工具

火热的低代码和无代码赛道

互联网工科生

软件开发 低代码 无代码 应用开发

到底该不该使用Python?

这我可不懂

Python Go 数据库

基于eBPF技术构建一种应用层网络管控解决方案

统信软件

专家老师带教!现场答疑!阿里云实时计算 Flink 版线下训练营北京站来啦!

Apache Flink

大数据 flink 实时计算

Apache Dubbo 云原生可观测性的探索与实践

阿里巴巴云原生

Apache 阿里云 云原生 dubbo

Apache 官方限定社区周边,Community Over Code 亚洲大会参会礼包抢鲜看!

Apache IoTDB

Office 2019 for Mac v16.77 beta中文激活版

mac

office办公软件 苹果mac Windows软件 office 2019

解决并发冲突:Java实现MySQL数据锁定策略

高端章鱼哥

Java MySQL 数据库

面向模式软件架构第4、5卷出版_架构_Niclas Nilsson_InfoQ精选文章