Clean Architecture读书笔记

第一部分 简介

第一章

Architecture的简介。

架构设计的目的:减少系统构建和维护的成本。

引入例子对比不同开发思路下维护软件的成本,说明架构的重要性。

第二章

功能开发 VS 架构设计

只注重功能开发不注重架构的系统是无法延续的。

引入Esenhower Matrix,把要做的事按重要程度和紧急程度划分在四个象限,并且排优先级。

架构设计不紧急但是重要,应该放在较高的优先级。


第二部分 编程范式

1. 结构化编程——限制了goto的使用,使得程序的正确性可被证明

2. 面向对象——限制了函数指针的使用,带来了多态,加强了代码依赖的控制,使依赖反转成为可能

3. 函数式编程——限制了赋值语句,把程序隔离成mutable和非mutable的部分,减少竞争、死锁等变量冲突

以上三种编程范式都限制了程序的行为,规范了程序底层的设计原则。


第三部分 设计原则

SOLID

规范了程序中层(mid-level)的设计原则


第四部分 组件原则

component是独立部署的最小单位。

component聚合的三原则:

REP: Reuse Release Equivalence Principle. component复用和发布的粒度应该一致。

CCP: Common Closure Principle,component级别的SRP

CRP:Common Reuse principle,component级别的ISP

component cohesion tension

处理component耦合的三原则:

1. the Acyclic Dependancies Principles:无循环依赖。component依赖关系应该是演进出来的,而不是设计出来的。

2. the Stable Dependencies Principle:不稳定component应该依赖稳定的component

3. the Stable Abstractions Principle:component的抽象程度和稳定程度应当成正比。


第五部分 架构

架构的目标是什么?

1. 功能的正常使用

2. 易于维护

3. 易于开发

4. 易于部署

如何达到这些目标?

通过把系统解耦成彼此独立的component,能让很多技术决策尽可能延后,降低在需求变化时改动系统的成本。

如何进行解耦?

系统的解耦主要有两种方式,一种按用户场景(use case),一种按代码层级结构(layer)。解耦之后,通过用户场景或者代码层级划分的各个component应该保证独立开发和独立部署。

解耦的级别有源码级别、部署级别、服务级别。

解耦之后,如何处理跨component的重复代码?

要识别真正的重复和偶然重复。如果两处相同的代码改动的原因、频繁不相同,那就只是偶然重复。

常见的偶然重复:数据库层的entity和展现层的DTO字段一样;用户场景A和B有相似的Request或者View Model。

划分边界

为了让系统内各组成部分保持独立,需要划分出各部分之间的边界。

业务逻辑是一个系统的核心价值,不应该依赖底层的具体技术细节,比如GUI和数据库。

划分边界的具体技术手段有很多,比如单体应用的内部分离、分离成可独立部署的模块、线程隔离、程序隔离(local processes)、服务。在一个系统里往往会有多种划分边界的方式。

整洁架构(Clean Architecture)

架构应该体现系统的功能,而不是使用的框架。

整洁架构的特点如下:

1. 可测

2. 架构无关

3. UI无关

4. 数据库无关

5. 外部组织无关

测试

测试不应该依赖系统脆弱的部分,比如测业务逻辑依赖GUI。

把难以测试的部分隔离,比如UI展示拆成无逻辑的Humble Object和包含所有显示逻辑的View Model,只针对View Model测试。

为测试提供专门的API验证业务逻辑,以防止测试与具体的实现耦合。


第六部分 细节

web、数据库、框架等等都是底层(low-level)的技术细节(details),上层(top-level)抽象的业务逻辑不应该依赖这些技术细节。要在架构内对核心业务模块屏蔽这些细节。

拾遗章节

程序的分包方式:

1. 按层级划分

2. 按功能划分

3. 端口和适配器

4. 按component划分

要架构的设计思想映射到分包甚至代码实现里,并通过静态的代码检查或者编译限制来强化这些限制。魔鬼总在代码实现里。



相关链接

1. http://butunclebob.com/ArticleS.UncleBob.PrinciplesOfOod

2. https://fideloper.com/hexagonal-architecture

3. http://www.codingthearchitecture.com/2015/03/08/package_by_component_and_architecturally_aligned_testing.html

4. https://gist.github.com/ygrenzinger/14812a56b9221c9feca0b3621518635b

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,802评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,109评论 2 379
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,683评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,458评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,452评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,505评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,901评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,550评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,763评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,556评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,629评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,330评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,898评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,897评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,140评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,807评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,339评论 2 342

推荐阅读更多精彩内容