架构设计是一个非常大的话题,不管写几篇文章,接触到的始终只是冰山一角,更多的是实践中去体会。这篇文章主要介绍面向对象OO、面向方面AOP和面向服务SOA这三个要素在架构设计中的位置与作用。
3 J- M! }3 F3 I, }. A f8 H8 \架构设计有三个维度,或者说是我们在考虑架构时需要思考三个方向。
, I( x1 R5 n. z这三个维度分别为面向对象、面向方面、面向服务。
; F% w7 X9 a2 C6 s这三个维度可以看作是正交的,但不同维度会互相印证,互相支撑,整个架构的示意图如图所示。
' z" z; ]* L, p0 e
 |
| 图:架构三维度结构图 |
面向对象
+ u8 t C* ]: `5 g面向对象技术最初是从面向对象的程序设计开始的,它的出现以上世纪60年代Simula语言为标志,并在Smalltalk语言的完善和标准化过程中得到更多的扩展和对以前思想的重新注解。
( l- z& i& o; w上世纪80年代中后期,面向对象程序设计逐渐成熟,被计算机界理解和接受,人们又开始进一步考虑面向对象的开发问题。直到现在,面向对象已经成为一种非常流行的编程方式,以及软件设计的架构。
( k' Z& v! Y3 W% M) N0 v
面向对象提出有三个主要目标:重用性、灵活性和扩展性,强调对象的“抽象”、“封装”、“继承”和“多态”。它能让人们以更加接近于现实世界的方式来思考程序,这点可以说是面向对象最大的进步。
$ e% Y2 H: J( u0 ?) d* X [
在OO思想的运用上,业界出现了很多好的经验与技巧,从而涌现出大量的设计模式,可以说面向对象是系统分析与设计时的一个很重要的方面。
. j* T" K1 O' F. t1 U
面向方面
! e" ]# \$ v+ A9 y% R. S面向方面最初来源于hook技术,本质上就是满足扩展的需求,可以在程序中自由扩展功能。
+ K. X/ o( m2 @* m7 n$ p面向方面不仅仅是一门编程技术,同样也是一种架构设计的思路。如果说OO是纵向地分析、切割整个系统,那么可以认为AOP是横向地对系统作切片。
/ h, p( B, P) s
简单地理解,OO与AOP分别从两个不同的角度给我们提供了分析系统的思路。面向方面可以弥补面向对象的缺陷,两种方式有机的结合在一起,可以更加有效地对系统进行分析。
. o; S; O4 u: I, h2 ~6 m7 h$ Y! Y我们认为OO是接近于人类认识自然的思维方式,但对于东方而言却并不一定是这样的。
4 @! F) `6 ^+ i' B当西方人看到一个复杂系统的时候,只会有一种思路,就是“分解”,将系统分解成一块一块,然后每个部分进行研究。
6 t# i% c+ ~& u7 y3 a+ E* J6 K' r
当东方人看到一个复杂系统的时候,更多地会关注系统中存在的关系,将系统作为一个有机的整体进行研究,这也是东方和西方在事物看法上存在的差异。
9 D2 X5 O1 J4 R( T! L9 D这两种思维方式都没有问题,如果结合起来分析问题,解决问题会更好。面向对象与面向方面也同样如此,都能对应到人类认识自然的思维方式上。
, _; G: M% a* u0 ]- A3 Y) \
面向服务
% P- ~' j) {/ w; S1 F面向服务可以说是最近炒得比较火热的概念。包括现在提到的SaaS(Software as a service),软件即服务。准确而言,面向服务不仅仅是软件行业的概念,这个要从社会的产业结构说起。
3 s/ X5 G9 B! O: R社会产业总共分为三个,第一产业农业,第二产业工业,第三产业服务业。最早社会的主要产业是第一产业农业,将近有几万年的历史。
3 g3 z, G$ b2 {- Q9 F十八世纪下半叶在英国开始的工业革命,对人们的生活产生了根本性的影响,社会的主要产业成了第二产业工业。
. l6 M) L' i. a. I( A2 I现在仍然属于工业时代,或者有人说的“后工业时代”。而在后工业时代,社会的经济体制必定要向第三产业服务业逐渐转型。面向服务其实是社会经济体制重心的一种迁移。
. {- {2 N. L+ H. y
还是说回到软件行业,社会的主要产业将转变成服务业,自然软件行业也会出现对应的变化,那就是这里提到的面向服务。面向服务今后会影响到软件的交付模式,会对整个软件行业的体制产生影响。
' ^- _" K/ T! c
而说到架构层面,面向服务是系统发布功能的一种方式。并且基于这种方式下不同的系统之间能有效地通信、协作。常见的实现技术就是Web Service。
9 s+ ^& b. {3 v
软件全局观
, B% H: q' r6 ]" Q3 p软件架构设计的三个维度:面向对象、面向方面、面向服务。
- b1 t# C6 h9 I8 H- S8 X最年长的一个维度就是面向对象,发展了好几十年,也是相对而言比较成熟的一个维度。它解决的问题是系统内部结构的设计。
& a' P8 {! E! p: }7 F/ ^6 B
面向方面思想的提出能够弥补面向对象的缺陷。面向对象的方式不能实现横切关注点的分离,而面向方面正是为了解决这个问题。面向方面与面向对象一样都是解决系统内部结构的设计。
! [) Y/ U1 q; v$ |
面向服务更多的是涉及到系统的外部,简单地说就是发布功能。它并不关注系统内部结构的实现,所以说面向服务与面向对象或者面向方面并不冲突。
5 Q! D! ]# f8 U9 N这三个维度并不是绝对孤立的,它们之间会互相影响、制约,相互发展的。我们在分析架构的时候需要同时考虑到这三个维度的问题,这样有助于我们设计出更加优秀的架构。