前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >从CAP到编程语言的猜想

从CAP到编程语言的猜想

作者头像
半吊子全栈工匠
发布2018-08-22 10:06:19
4520
发布2018-08-22 10:06:19
举报
文章被收录于专栏:喔家ArchiSelf喔家ArchiSelf

TIBOE 有如期的发布了最新的编程语言的排行榜,变化总是有的,这是今年3月的榜单:

关于编程语言的争议总是有的,不论是各个论坛,微信群,QQ群,乃至知乎,Quara 等知名网站,总会有对各种编程语言的吐槽。一句“PHP是世界上最好的语言”可能会引起一场又一场的激战,这句话仿佛成了一个“梗”,自己也无法免俗,忍不住写了一篇《PHP是最好的语言吗》,但编程语言鄙视链的存在令很多人无休止的追问,这不应该只是一种程序员间的乐此不疲吧?!

在微服务中,数据库的集成是一件不会令人愉悦的事,因为分布式系统CAP理论在起作用吧。

中生代的右军有文章专门对CAP进行了论述。

* Consistency(一致性),数据一致更新,所有数据变动都是同步的

* Availability(可用性) 好的响应性能

* Partition tolerance(分区容错性) 可靠性

CAP 的核心思想是任何分布式系统只可同时满足二点,没法三者兼顾。

那么,由此类比到编程语言会是怎样的情景呢?

是否可以对编程语言进行抽象呢? 而且抽象到3个维度呢?

根据自己所用过的编程语言的经验(35岁前曾经每年学一门编程语言),仿佛可以把编程语言归纳到3个约束:Simple,Adaptive,Performance——SAP:

Simple 简洁明快

* 编程语言的读与写都容易理解,学习曲线平滑而且短

* 结构紧凑,容易协作与维护

* 拥有丰富的类库,以及完善的参考手册

* 依赖少,部署同样简单

......

Adaptive 适用性强

* 适用于多个应用领域,支持各种层次的抽象

* 伸缩性好,增减依赖都很方便

* 支持多种编程范式

* 可编译执行,也可解释执行

* 甚至可以定制派生的语言

......

Performace 性能高效

* 不论使用IDE还是文本编辑器,代码编写都很快

* 执行速度快,充分利用CPU甚至GPU的能力

* 编译的速度同样快,支持JIT

* 故障定位的速度快,debug快捷精准

......

如果分成这样3个属性,会发现它们之间存在着内在的矛盾,就像CAP那样:

SA 是Python,Java,还是......?

AP 是C,C++, 还是 ......?

SP 难道是 汇编么,还是 ......?

CAP 给我们的启示是 架构师不要将精力浪费在如何设计能满足三者的完美分布式系统,而是应该进行取舍

如果SAP 的猜想是成立的,那么给我们带来怎样的启示呢?

会不会混合编程是一种必然呢?

没有仔细阅读过CAP的数学证明,也没有努力想用数学的方法去证明SAP的成立,现在只是老码农的猜想,可能是一种错误或者遗憾吧。

回顾一下编程语言的历史,献上一张来自veracode.com的旧图:

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2017-03-11,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 喔家ArchiSelf 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档