软件设计之美
郑晔
推文科技技术VP,前火币网首席架构师
立即订阅
3411 人已学习
课程目录
已更新 34 讲 / 共 36 讲
0/4登录后,你可以任选4讲全文学习。
开篇词 (1讲)
开篇词 | 软件设计,应对需求规模的“算法”
免费
课前必读 (3讲)
01 | 软件设计到底是什么?
02 | 分离关注点:软件设计至关重要的第一步
03 | 可测试性: 一个影响软件设计的重要因素
了解一个软件的设计 (4讲)
04 | 三步走:如何了解一个软件的设计?
05 | Spring DI容器:如何分析一个软件的模型?
06 | Ruby on Rails:如何分析一个软件的接口?
07 | Kafka:如何分析一个软件的实现?
设计一个软件—程序设计语言 (5讲)
08 | 语言的模型:如何打破单一语言局限,让设计更好地落地?
09 | 语言的接口:语法和程序库,软件设计的发力点
10 | 语言的实现:运行时,软件设计的地基
11 | DSL:你也可以设计一门自己的语言
加餐 | 再八卦几门语言!
设计一个软件—编程范式 (9讲)
12 | 编程范式:明明写的是Java,为什么被人说成了C代码?
13 | 结构化编程:为什么做设计时仅有结构化编程是不够的?
14 | 面向对象之封装:怎样的封装才算是高内聚?
15 | 面向对象之继承:继承是代码复用的合理方式吗?
16 | 面向对象之多态:为什么“稀疏平常”的多态,是软件设计的大杀器?
17 | 函数式编程:不用函数式编程语言,怎么写函数式的程序?
18 | 函数式编程之组合性:函数式编程为什么如此吸引人?
19 | 函数式编程之不变性:怎样保证我的代码不会被别人破坏?
加餐 | 函数式编程拾遗
设计一个软件—设计原则与模式 (7讲)
20 | 单一职责原则:你的模块到底为谁负责?
21 | 开放封闭原则:不改代码怎么写新功能?
22 | Liskov替换原则:用了继承,子类就设计对了吗?
23 | 接口隔离原则:接口里的方法,你都用得到吗?
24 | 依赖倒置原则:高层代码和底层代码,到底谁该依赖谁?
25 | 设计模式:每一种都是一个特定问题的解决方案
26 | 简单设计:难道一开始就要把设计做复杂吗?
设计一个软件—设计方法 (3讲)
27 | 领域驱动设计:如何从零开始设计一个软件?
28 | 战略设计:如何划分系统的模块?
29 | 战术设计:如何像写故事一样找出模型?
巩固篇 (2讲)
30 | 程序库的设计:Moco是如何解决集成问题的?
31 | 应用的设计:如何设计一个数据采集平台?
软件设计之美
15
15
1.0x
00:00/00:00
登录|注册

08 | 语言的模型:如何打破单一语言局限,让设计更好地落地?

郑晔 2020-06-10
你好!我是郑晔。
经过前面几讲,我们已经学习了如何去了解一个现有软件的设计。从这一讲开始,我们就进入到新的模块,讨论如何设计一个软件。做设计之前,我们要先知道手边有哪些工具。所以在这个模块开启之初,我们先来讨论程序设计语言。
或许你会觉得,程序设计语言有啥好讨论的?哪个程序员没有一门看家的程序设计语言呢?不知道你是否遇到过这样的问题:
面向对象用来组织程序是好,但我用的是 C 语言;
我用的是 C++,函数式编程的好,跟我有什么关系;
动态语言那些特性很好,可惜我用的是 Java;
……
如果你这么想,说明你被自己的看家本事给局限住了,这种思维方式会让你即便学到了更多的好东西,也只能无可奈何。
其实,程序设计语言之间没有那么泾渭分明的界限,程序员唯有多学习几门语言,才能打破语言的局限,让设计更好地落地。你可以根据项目特点选择合适的语言,也可以将其它语言一些优秀的地方借鉴过来。Andrew Hunt 和 David Thomas 在《程序员修炼之道》(The Pragmatic Programmer)中给程序员们提了一项重要的建议:每年至少学习一门新语言。
可是,语言那么多,我要一个一个都学过去吗?学语言到底在学什么呢?
其实,程序设计语言本身也是一个软件,它也包含模型、接口和实现。而我们学习程序设计语言主要是为了学习程序设计语言提供的编程模型,比如:不同的程序组织方式,不同的控制结构等等。因为不同的编程模型会带给你不同的思考方式。
取消
完成
0/1000字
划线
笔记
复制
© 版权归极客邦科技所有,未经许可不得传播售卖。 页面已增加防盗追踪,如有侵权极客邦将依法追究其法律责任。
该试读文章来自付费专栏《软件设计之美》,如需阅读全部文章,
请订阅文章所属专栏新⼈⾸单¥19.9
立即订阅
登录 后留言

精选留言(13)

  • 业余爱好者
    操作系统等各种软件有模型,编程语言也有模型,计算机世界里模型真是无处不在啊。模型就是一种看待世界的方式,一种模型的提出的最大的动力是为了解决某个问题。

    编程语言的发展就是各种编程模型的演化。从图灵机模型到冯诺依曼的存储程序模型,机器语言,汇编,一直到千姿百态的高级语言。每种语言都提供了一个编程模型,这个模型越来越高级,越人性化,越贴近人的思维。

    拿自己熟悉的java语言举例。尽管java是用c++语言写成的,但Java提供了不同于c++的内存与线程模型(Java的六种线程状态并不与os的各种线程状态一一对应,内存的划分也是如此),大大简化了开发。


    每年学一门新语言,也就是每年学一个新的编程模型。

    作者回复: 很好的补充,我这里只说了语言的演变,你补充的线程信息很好!

    2020-06-10
    1
    10
  • qinsi
    两本《七周七语言》里包含的语言:

    Clojure, Haskell, Io, Prolog, Scala, Erlang, and Ruby
    Lua, Factor, Elixir, Elm, Julia, MiniKanren, and Idris

    几年前因为感到规模化的js工程需要类型,调研过Elm、BuckleScript和TypeScript,今天看来赢家不言而喻

    作者回复: 能被记住的就是赢家。

    2020-06-11
    4
  • 北天魔狼
    非科班PHPer,今年目标拿下C语言
    参考书是《深入理解计算机系统》,我看不懂,所以我又找了《计算机是怎样跑起来的》,《程序是怎样跑起来的》,《网络是怎样连接的》,《图解HTTP》,《图解TCP/IP》,现在就剩程序和网络那两本没看,这个月看完。下个月开始死磕《深入理解计算机系统》

    作者回复: 嗯,C 语言是弄懂计算机结构的好入口。《深入理解计算机系统》是非常好的书,不过,确实不容易读。

    2020-06-10
    2
    4
  • Jxin
    1.最早了解到LISP,应该是在Paul Graham的Hacker News和Arc语言(为了证明Arc写了Hacker News,Arc没火Hacker News却火了)。
    2.Paul Graham提出了著名的 Blub 论断,这个论断讨论这样一个问题:“不同的编程语言到底有什么不一样?是不是一种编程语言比另外一种编程语言更高级?”
    3.为了表达观点,他引入了一个叫作 Blub 的语言。这个语言比机器上的二进制语言要高级一点,但是比市面上的任何高级语言都要低级。为什么从一个使用 Blub 语言的程序员的角度去看,机器上的二进制语言是一个更加低级的编程语言?因为它缺乏了 Blub 拥有的语言特性。但是从一个使用二进制编程语言的人的角度来看,其实两者没什么差别,因为即便有多余的特性,二进制语言编程者也不会去用那些东西,而只会用属于二进制语言的那个子集。
    4.结论就是: 使用更高级语言的人知道低级语言缺乏了一些高级语言的特性,所以低级语言显得更原始,而低级语言的开发者却无法发现高级语言里面蕴含的额外的语言特性。
    5.我的认知: 个人不喜欢高低之分,毕竟存在即合理,每款现存的语言都会有它高的地方和低的地方。但是Paul Graham的论断其实也反应了一些问题。就是人们往往会陷于自己的已有认知(毕竟阻力最小)。做为一个java程序员,无论是写py还是写go多多少少都有点用py和go语法写java代码的味道(也因为我在py和go的水平不够)。所以栏主所说的,学习语言是增量学习这个是对的,但已有认知也会是陷阱,这就导致我可以很快学会一门语言的语法,但很难接受其背后的编程模型。已有认知带来的偏向性会让人对新的编程模型带有抵触的情绪。外在表现就是,喜欢在其他语言中找不足来满足自己内心的偏向心理。

    6.我们这次专栏是软件设计之美,重在设计。深入语言这种,感觉背景比设计理论都要重。ruby和这章感觉要理解栏主表达的意思都显得比较吃力。是只有我能力不足吗?栏主可有什么书籍推荐?

    作者回复: 感谢你做出这么棒的分享!

    在内容中说了,之所以要讲语言就是为了打破语言局限,在后面的内容中,你就会看到,有用 C 语言实现面向对象的,有用 Java 实现函数式编程的。做设计,拥有各种设计思想固然重要,但更重要的是,能够把它实现出来。

    慢慢来,这是一个系列的内容,等这几篇之后,你再有不理解的话,我们可以来好好讨论一下。

    2020-06-10
    3
  • Harry

    看过此文才知道,自己还在从 0 到 1 的阶段。

    作者回复: 然后,就可以飞起了!

    2020-06-12
    2
  • 陈政璋
    看过很多文章都提到过编程模型,一直没理解编程模型到底指的是什么。
    2020-06-12
    2
  • escray
    项目经验比较少,所以反而不太受语言的限制,C#、Java、Ruby 都能写一些,Python、JavaScript 也都接触过,不过缺点就是每一门语言都不是很精通。

    看过《程序员修炼之道》,对于每年学一门新语言也很向往,之前还考虑过挑战一下《七周七语言》。但是确实没有仔细考虑过为什么要学,以及如何学得更有效率。

    发现文章在描述语言发展史的时候没有提到 C#、JavaScript 和 Go,当然还有一些其他的语言。C# 应该和 Java 比较类似,JavaScript 接近动态语言,但是因为 V8 引擎,又有些不太一样,Go 语言我就不知道该如何定位了,好像是结余 C 语言和 Java 之间。

    之前并不喜欢 Java(其实是因为我没有看到 Java 最近几年的发展),但是发现在工作市场上,Java 的机会远多于 C# 和 Ruby。

    每一种语言(或者框架)的出现,其实都是试图解决某种问题,如果能丰富一下自己的“兵器库”,当然会带来软件设计功力的提升。

    那么问题来了,感觉一年时间(工作之余)其实不足以掌握一门编程语言,因为还要需要学习一些周边的框架和工具等等,这个问题怎么破?

    后面如果有时间,想要学习一下 Go 语言。

    作者回复: 加餐一期,算是对这个留言的回复。
    https://time.geekbang.org/column/article/249596

    2020-06-10
    2
  • 六一王
    我是做前端开发的,有往全栈方向发展的打算,文中说的一种新语言的编程模型,那我选择最近学习 typescript 算是一种新语言么?

    作者回复: 如果你只用过JavaScript,那TypeScript值得一学,它提供了更好的程序组织方式。

    2020-06-10
    2
  • happychap
    刚玩了下小众非主流的小应用场景的jsonnet~
    2020-06-15
    1
  • 不记年
    emmm 不是特别同意 一切语法都是语法糖这个观点. 我认为实现编程模型的原语集的语法(对于java来说就是class, public, private ...)不是语法糖,因为拿掉了 编程模型就不完备了.再此之外的语法 我觉得可以认为是语法糖~
    2020-06-12
    1
  • 张逃逃
    js,前端后端跨平台全搞定

    作者回复: 理想很丰满,现实很骨感。

    2020-06-10
    1
  • 阳仔
    作为一个老程序猿使用的编程语言有Java,Python,golang,kotlin。每种编程语言都有自己编程模型,一个编程语言都是为了解决现有的问题而出现的。从汇编语言到高级语言,从过程编程到面向对象编程,从线程模型到协程模型…都是一个不断进化发展的过程,也是编程思维的升级。建议程序猿每年学习一门新语言其实也为了理解编程语言的模型思维,从而更好的理解软件设计。

    作者回复: 非常好的补充!

    2020-06-10
    1
  • 三生
    打算学习julia,因为性能强大语法也简单

    作者回复: Julia有一个不错的目标,希望它也能够快速成长。

    2020-06-25
收起评论
13
返回
顶部