09 | 语言的接口:语法和程序库,软件设计的发力点
消除重复的程序库
- 深入了解
- 翻译
- 解释
- 总结
程序设计语言的接口包括语法和程序库,程序库的设计是语言设计的一部分。程序库的作用是消除重复,提供更丰富的选项,甚至修正标准库的bug,使开发变得更简单。程序库设计就是语言设计,例如,new操作和synchronized在Java中成为了语法,但在一些场景下,语法反而会显得僵化,这时候又轮到程序库登场。程序库设计的一个重要方面是工厂模式,通过静态工厂方法代替构造函数,可以更清晰地表达代码的意图。通过程序库的设计,可以提供更清晰、更简洁的编程模型,成为软件设计的发力点。 文章讨论了程序库和语法之间的相互促进关系。它指出,解决同一个问题可以使用语法或程序库,二者之间是等价的。程序库的发展推动着语言的不断进步,有一部分语法是为了让程序库表现得更好而存在的。因此,学习编写程序库是提升软件设计能力的重要路径之一。文章还提到了一些语法和程序库互相促进的例子,如C中的宏、Java中的Annotation以及Scala中的隐式转换。 总的来说,程序库设计是语言设计的一部分,二者相互促进,不断发展。理解了模型和接口,可以借鉴不同程序设计语言的特点,而提升软件设计能力可以从编写程序库入手。
《软件设计之美》,新⼈⾸单¥59
全部留言(23)
- 最新
- 精选
- qinsi想到两个观点: 1. “设计模式是缺失的语言特性”。比如在函数是一等公民的语言中,至少有半打的设计模式是不需要的。 2. “所有非平凡的抽象(abstraction)在某种程度上都是有漏洞的(leaky)”。封装的程序库只能工作在某个抽象层次上,总会遇到无法在该抽象层次上解决的问题,此时只能绕过这层抽象从更低的抽象层次上解决。
作者回复: 非常好的补充,后面讲到设计模式,我也会提到类似的观点。
2020-06-1328 - Jxin1. 《Effective Java》是本好书,需要尽早一读。 2.今天记住的是这句话。语言设计就是程序库设计,程序库设计就是语言设计。眼前一亮的感觉。 3.程序库和语言都属于加法容易,减法难的范畴。除了抽象去重外,其实更重要的是识别什么不该做,以及如何设计向后兼容,易扩展的代码结构。 4.事实上,很多程序库,为了保证灵活,性能,向后兼容,功能全面。内部代码量会比较大。如果提高设计能力,起步就是程序库,感觉会比较吃力。(写过公共工具包,为此看了hutool和guava等的源码,前者散乱后者优雅,但都不好啃)。在有一定认知后,才能看出一些端倪。 所以,起步的话,把《重构-既有代码改善》看了,内容简单易懂。然后在项目中持续重构自己的代码,跟自己较真,多思考。每次重构都是在重审自己对设计的理解,循序渐进。
作者回复: 可能是我的偏见,国人的开源项目代码质量高的不多,除非这个项目有大量的老外参与,或者作者之前在外企工作。
2020-06-1220 - yudidi我看到文中这句话时:"它们会在标准库的基础上,再做一次封装,提供一个新的编程模型", 第一反映想到了这篇博客https://www.iteye.com/blog/downpour-1330537, 其中也提到"编程模型"这个词汇。做过java开发的同学, 建议看看, 非常有助于理解老师的这节课。 我的理解: 在标准库jdk的基础上,struct和springmvc再做了封装,提供了2种新的编程模型,最后springmvc的编程模型胜出。
作者回复: SpringMVC从模型上确实简单一些,但它胜出依赖的是Spring,或者说作者的整体品味。
2020-06-1337 - westfalljs 里的 promise,最早是社区弄出来的,最后却成了 js 语言的一部分
作者回复: 异步处理的发展也经过了一个很有趣的发展过程,从最开始的写进程线程,到后面的 promise/future,到现在的响应式编程。演化还还有结束,还有很多的东西正在进行中。
2020-06-184 - happychap一言不合就开车,一码不便就撸库。确实在语言发展历程上,每门好的语言都有其精华,目的还是在用不同的编程哲学适应不同的应用场景。用golang的伙伴会得意于编译出的程序内存占用少,goroutin如何方便,函数支持多返回值是多么的优雅,而用java的伙伴则乐于能用到泛型、重载、多态等特性,能用到spring等等功能异常强大的框架。编程知识大爆炸的年代,语言小巧够用感觉更环保些ʘᴗʘ
作者回复: 非常好的补充!
2020-06-154 - Y024嗯,我又来强行插入第一季了,“学习一种程序设计语言提供的模型时,不仅仅要看语法本身有什么,还要了解有语言特性的一些程序库。”这不就是第一季提的扩大上下文吗?🤔
作者回复: 嗯,也是一个理解的角度。
2020-06-124 - 阳仔程序语言的接口是程序库。我们可以通过学习和开发程序库来提高自己的程序设计能力。 程序库的开发是为了消除重复。经常遇到的编程模型和重复的功能逻辑都封装成程序库,可以提升编码效率和体验。 除了使用语言提供的标准程序库还需要理解其它常用的第三方程序库,这些库也是解决某种问题而存在,也是对标准库以及其它三方库的封装。 很多语言使用包管理器工具管理这些常用库(这也是一个解决问题的模型) 语言设计和程序设计是相互促进、相互影响的。 好的编程模型会被整合进语法糖成为语言设计的一部分,而好的语言接口也影响程序设计的模型
作者回复: 很好的总结!
2020-06-123 - escray如果按照语法、程序库、运行时的节奏,我对于几个语言(Java,C#,Ruby)的理解大部分停留在了程序库这一步,而且运用的不怎么熟练。 “语言设计就是程序可设计,程序库设计就是语言设计”,专栏中提到说二者是为了解决同样的问题,那么这个问题是什么,是为了消除重复? 学习编写程序库对我来说有点无从下手,不过我觉的可以看一些优秀的开源程序库代码,也许是个不错的选择。 我有一个感觉,各种不同的语言和程序库之间其实是相互促进的关系,Java 其实也是在不断的演化,再加上 Guava 等程序库的加持(当然还有 Spring 系列的框架),焕发新春。
作者回复: 设计主要都是消除重复,只不过,有的人是通过设计新模型消除重复,有的人是通过把代码块抽到一起消除重复。 阅读优秀程序库的源码是一个人自我提升的一种途径,这是值得鼓励的。
2020-06-172 - yudidi醍醐灌顶
作者回复: 欢迎邀请小伙伴共同提高!
2020-06-132 - petit_kayakboost和现代C++之间就是典型的语言与程序库互相促进的故事
作者回复: 很好的分享
2022-01-231