Golang 设计哲学

原文:http://blog.csdn.net/hittata/article/details/43668569

这是一篇转载,没有通知原作者就转载了。如果有需要,可与我联系,删除这篇转载。转载时修改了一下格式和一些明显的笔误。


世界是并行的——先不说宇宙,就整个地球来说,世界万物都是并行发生的;天生对并发支持良好的 go 语言更容易描述并行的世界;

世界是由物质组合构成的——微观世界:由小的粒子组合成大的粒子;宏观世界:由小的物体组合成大的物体;继承只能描述现实世界的一小部分,使用继承是不全面的;go 的设计选择的是组合,这个和现实世界比较吻合的设计,表现力更强;

世界是标准化的——随着生产力的发展,社会分工越来与详细,越来越多行业有了国际标准,任何一个国家的、任何一个公司只要按照这个标准生产器件,就能装配到一台机器上;IBM/PC 就是硬件模块化和接口化一个最成功的例证;软件也可如此,go 的接口是 duck 模型,面向接口编程,而不需要显示的声明,将语言能做的事情交给语言做;

正交性——几何上的正交指的是两个向量垂直关系,一个向量在另一个向量方向的投影是一个点;现实中的正交是指多个因素,一个发生变化,不会影响其他的因素;在不减少表现力的情况下,正交是保持事物稳定性和简单性的最好设计;go 很好的遵循了这个规律,go的多个特性之间都是正交的:goroutine、接口、组合、类型系统等;举一个典型的正交设计例子:比如客户嫌雨伞太小,单纯的加长伞杆是不行的,这会增加雨伞的长度;最后计出折叠式的雨伞;这种设计能保证雨伞大小和雨伞长度满足正交关系,当然这会增加雨伞生产的复杂性)把复杂性留给厂家,把便利性留给客户;对于编程语言:尽量把复杂性留给语言实现者和编译器,把简单性留给语言使用者,这才是一种好的语言;

少即是多——没有万能的语言,换句话说一门语言不可能包含所有的特性;想囊括所有特性的语言一定是非常的复杂(C++);保持简单性的方法就是:每种特性仅提供一种方法,减少重复、冗余,试想一下,如果汽车有多个刹车板,你会感觉更安全,更便利吗?只提供一种方法做事情,把事情做到极致,这就是 go 的原则,解放程序员,不要给他提供很多雷同的功能和语句,这不会使问题简单,只会加重程序员的心智负担。

二八定律——在编程语言中描述就:百分之八十的代码仅仅使用到百分之二十的语言特性,增加语言特性,并不能保证开发效率的提升,原因是它会增加复杂性,导致更容易犯错;有些复杂的编程问题其实可以通过库的形式来辅助支持;大部分异常与错误——所谓异常就是没有预料到的非期望的事情发生了,所谓错误就是预料到的非期望的事情发生了;go 语言把两种情况终于给分清楚了;什么是防御性编程,怎么保持程序的健壮性;每次调用都检查 error 确实让代码挺不美观的,个人认为为了健壮性,进行防御性的编程也是可以接受的;通过一定的技巧是可以避免错误代码冗余性;

论述完普世定律后,我来总结一下GO语言的哲学:

  1. 面向接口编程
  2. 使用组合的编程
  3. 正交性:语言设计的正交性,保证语言的稳定性和简单性
  4. 少即是多:有且仅有一种方法把事情做好做对
  5. 并发语言层面支持:并发更好利用多核,有更强的表现力来模拟真实世界
  6. 开放性:开源,语言的实现对程序员不是个黑盒子,任何想了解语言实现的人都可以参与进来

go 没有像 JAVA 一样,宗教式的完全面向对象设计;完全面向对象设计就是一刀切的宗教式的设计,但其并不能很好的表述这个世界,这就导致其表现力不足,最后通过设计模式和面向切面等设计技巧来弥补语言方面的缺陷;go是面向工程的实用主义者,其糅合了面向对象的设计,函数式设计和过程式设计的优点;原来通过各种设计模式的设计通过函数、接口、组合等简单方式就搞定了;go 有更多胶水的东西比如:全局变量、常量,函数,闭包等等,可以轻松的的把模块衔接和驱动起来; JAVA 就好比:手里握着是锤子,看什么都是钉子,什么都是类的对象,这个和现实世界不符,类表示单个事物还可以,一旦表示多个事物及其交互,其表现力也就会遇到各种挑战。

是时候该转变观念了,不要动不动就提面向对象设计,动不动就提设计模式(特指某些招聘伪专家);编程的世界是多样的,编程思想和范式是丰富多彩的,不要再沿着错误的路线继续前进了,拥抱 go 吧。


原文发表于 2015 年 2 月,作者 @liwenta

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

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,065评论 25 707
  • TITLE: 编程语言乱炖 码农最大的烦恼——编程语言太多。不是我不学习,这世界变化快! 有时候还是蛮怀念十几、二...
    码园老农阅读 5,264评论 2 35
  • 前言 Unix是开源运动历史上最著名的代表之一,而如今前端是开源运动中最活跃的一支队伍,我相信它们两者之间一定有共...
    云峰yf阅读 3,115评论 0 6
  • 总结一下了解的设计模式 工厂方法和抽象工厂 这个是我们用的最多的设计模式也是最简单的设计模式,可能大家平时都用了。...
    码农苍耳阅读 205评论 0 0
  • 心理学家约翰·戈特曼通过对3000个美国家庭、700对新婚夫妻长达40年的跟踪研究,发现80%离异夫妻婚姻破裂的原...
    f3f795d3cb88阅读 714评论 0 0