对于开发者来说,"设计模式" 这个概念肯定不陌生, 它是经过分类的, 代码设计经验的总结, 能将编写代码进行工程化, 从而提升开发效率.
简单地理解, 它就是 "代码模板".
设计模式 + 代码逻辑 => 清晰高效的程序
"写作模式" 这个叫法也借鉴于此, 是我针对一些热门技术文章的写作方式进行的总结, 能帮我们快速地构思出结构清晰的文章.
下面通过 7 篇热门技术文章来总结 7 种写作模式.
清单式
举例
2018 年你需要知道的 11 个 JavaScript 库 https://blog.fundebug.com/2018/07/02/11-js-utility-you-should-know-in-2018/ 大纲:
- Lodash & Underscore
- Ramda
- MathJS
- Moment & date-fns
- Sugar
- Lazy
- CollectJS
- ChanceJS
- ChartJS
- Polished
- Mout
- Voca
- Licia
这里列举了 13 个 GitHub 上 star 数量较多的 js 库, 各个库之间是并列的, 相互之间并没有直接联系, 即使调换说明顺序也不会对文章造成影响.
模式
代码
这种模式结构非常简单, 我们可以直接用数组的形式来描述它:
- [
- sectionA,
- sectionB,
- ...
- sectionX,
- ]
小结
把同一类 (一般是并列关系) 的知识 / 技能点汇聚起来, 分条进行阐述. 适用于有一定关联关系, 但逻辑性不强的碎片化的知识点.
对比式
举例
为什么 Goroutine 能有上百万个, Java 线程却只能有上千个? https://mp.weixin.qq.com/s/v-Q5aOnYVj7l-kMQopkPLA 大纲:
到底什么是线程?
JVM 线程使用固定大小的栈
Go 线程使用动态大小的栈
JVM 线程上下文切换成本高
Go 线程切换成本低
结论
作者用 JVM 来指代 Java 语言, 针对线程占用内存空间以及 CPU 的使用率两个方面, 对 JVM 和 Go 进行了对比.
模式
代码
这种模式可以理解为 "清单式" 的 2.0 版本, 所以我们用对象数组来描述它:
- [
- // 文章主体
- {
- featureA: xxx,
- featureB: xxxx,
- ...
- },
- // 参照对象 1
- {
- featureA: yyy,
- featureB: yyyy,
- ...
- },
- ...
- ]
小结
将两三个类似的概念放在一起讨论, 在一些特定的维度上将两者进行对比, 最后总结出结论.
疑问式
举例
为什么给你设置重重障碍? 讲一讲 web 开发中的跨域 https://zhuanlan.zhihu.com/p/39466226 大纲:
一, 跨域是个什么问题?
二, 为什么不让我跨域?
三, JSONP-- 最常用的绕过办法
四, 为什么 JSONP 可以?
五, 跨域资源共享(CORS)
六, 不让跨域请求? 还可以直接跨网页
文章按照 what(什么是跨域) -> why(为什么会跨域) -> how(怎么解决跨域) 的思路来进行的写作, 具有一定的递进关系.
模式
代码
因为这种模式的出现已经有弱逻辑关系了(顺序上有依赖, 内容上无依赖), 用串行的函数来描述它最适合不过了:
- const sectionA = what();
- const sectionB = why();
- const sectionC = how();
小结
通常由多个相关联的问题组合而成, 逻辑关系层层推进, 比如 why(为什么),what(是什么),how(怎么样).
发散式
举例
普通程序员怎么理解日志系统 http://www.algorithmdog.com/loggingsystem 大纲:
Logging 系统的雏型
什么时候打印日志是个问题 -- Level
打印日志到哪里是还是一个问题 -- Appender
日志什么样也是个问题 -- Formatter
高效地打印日志是另外一个问题 -- Efficient
总结
围绕日志系统分条陈述, 包括日志级别, 内容, 存储, 内容, 性能.
模式
代码
可以用 JSON 数据类型来描述这种结构
- {
- sectionA: xxx,
- sectionB: yyy,
- sectionC: zzz,
- ...
- }
小结
和清单式有些相似, 但它是将一个具体的概念拆分成多个部分, 然后针对每个部分进行阐述.
流程式
举例
如何 Docker 化任意一个应用? 你需要参照这 10 步 https://mp.weixin.qq.com/s/bJX6DVEhM7Ti11tIgjUSsQ 大纲:
选择基础镜像
安装必要软件包
添加自定义文件
定义容器运行时的用户权限
定义暴露的端口
定义入口点(entrypoint)
定义一种配置方式
外部化数据
确保处理好日志
轮转日志和其他仅追加文件
作者按照操作流程编写文章, 具有强逻辑.
模式
代码
我们还是用函数来描述逻辑.
- const sectionA = step1();
- const sectionB = step2(sectionA);
- const sectionC = step2(sectionB);
- ...
小结
这种模式并无太多技巧可言, 通常适合实践类型的文章, 按照操作顺序来讲解.
探索式
举例
GO 千万级消息推送服务 https://yuerblog.cc/2018/06/26/go-push-service/ 大纲:
技术核心难点
解决技术难点
架构考量
源代码
文章结构简单, 逻辑清晰, 先提出技术难点, 然后给出技术解决方案.
模式
代码
这种探索方式和循环有些类似:
- while(!isBest(solution)) {
- solution = findBetterSolution()
- ...
- }
小结
针对开发中的某个问题一步一步探索最优解决方案. 一般的思路: 提出问题 ==>寻找解决方案 ==>现有方案的问题 ==>最终优化方案.
插画式
举例
你闺女也能看懂的插画版 Kubernetes 指南 http://www.yunweipai.com/archives/8056.html 这篇文章比较特别和少见, 没有明确的提纲, 但是丝毫不影响阅读体验, 因为图文穿插的方式能够缓解阅读疲劳, 同时更容易理解.
模式
代码
如果要用代码来表示这种模式的话那么我们可以把图片看成注释来进行描述:
- // comment sectionA
- sectionA
- // comment sectionB
- sectionB
- ...
小结
图文结合, 生动形象.
总结
总结一下本文提到的 7 种写作模式, 他们是:
清单式.
对比式.
疑问式.
发散式.
流程式.
探索式.
插画式.
当然我们在写较长的文章的时候可以将多种写作模式结合起来, 全文用某种模式, 而不同章节内部用其它模式.
如果要把这 7 种写作模式抽象成写作原则的话, 那么可以用两个词概括: 转化和联接 .
何谓转化?
把复杂的事情讲简单.
把简单的道理讲深刻.
何谓联接?
把分散的东西关联起来.
把关联的东西拆开对比.
最后给读者一个思考题来检验阅读效果: 本文属于那种写作模式, 你有没有看出来呢?
来源: http://www.tuicool.com/articles/6VniqyQ