[返回网际谈兵首页]·[所有跟帖]·[ 回复本帖 ] ·[热门原创] ·[繁體閱讀]·[版主管理]
耦合
送交者: 狂心中[♂☆★★★★如狂★★★★☆♂] 于 2021-03-02 20:05 已读 628 次 1 赞  

狂心中的个人频道

一、执念 6park.com

微软最有执念而硬着头皮搞了四十多年都不成功的一个东东叫 Basic,仅仅因为盖茨起家是靠它 (参阅《BIOS 和 PC 的故事》)。 6park.com

创始人的执念有时是巨大的浪费。 6park.com

直到去年微软才正式放弃了 Visual Basic。这几十年间,Basic 糟蹋了好多代人的青春。 6park.com

如果你学会了 Basic 语言里 GOTO 这个神奇命令,那么学习其它语言将特别难。 6park.com

软件是现实世界的数字化。而在现实世界里,无数对象是耦合在一起的。 6park.com

你没法在一秒钟内从北京 GOTO 到巴黎,你需要坐飞机。哪怕你走着去,你也要和鞋还有路以及地图发生关系。 6park.com

这些都是对象,飞机也是。 6park.com

二、对象 6park.com

大型飞机由几十万个的零部件耦合而成,每个零部件也是个对象。 6park.com

737 Max 的系统并没有明显逻辑 bug,但它没考虑冗余:一个攻角传感器出错了,MCAS 软件认为机头太高面临失速,它强行接管了飞行员不给反抗机会。 6park.com

所以这个锅不该印度码农来背,显然这是波音的软件架构师太草率了,测试也严重不足。 6park.com

波音用最简单粗暴的方式解决了此问题:两个攻角传感器必须信号一致 MCAS 才启动,而且飞行员随时可以接管 MCAS。 6park.com

这样,之前坠机的问题肯定解了。不过在特殊情况下,对飞行员的能力要求提高了。 6park.com

6park.com

波音在飞行核心控制上常使用一种强限制性的编程语言:Ada。 6park.com

不过,由于 Ada 在程序员中的人口比例太少,如同景德镇的足球人口在高考内卷下骤减,使得其产出严重对不起投入。 6park.com

F35 战斗机的关键系统改用 C/C++,因为无法承受 F22 在 Ada 上的高昂成本和稀缺的程序员。 6park.com

SpaceX 和特斯拉的核心语言也是 C/C++。 6park.com

三、语言 6park.com

有人说:等等,Linus 大神说过 C++ 是一种糟透了的语言。业界很多人在试图用 Rust 取代 C++。 6park.com

6park.com

面向对象编程确实也不像 n 年前那样是金科玉律。我自己觉得 C++ 写的 Office 套件大概是系统里最容易崩溃的应用了。 6park.com

人类的智力,难以解耦 shi 山一样的 C++ 遗留代码。 6park.com

Linus 没错,但不是所有应用都像 Kernel 那样,可以花很多年用 C 语言 (不用 C++) 精心打造那些固定功能。 6park.com

避免重复发明轮子 (对象),才是现代编程语言的关键。 6park.com

对微软来说,刚好和 Basic 被高估数十年相反,Anders 大神打造的最均衡的语言 C# 是长期被低估的。(参阅《程序员之神》) 6park.com

10 多年前微软曾尝试过用 C# 重写整个 Windows 应用层,以获得更高的安全和更可靠的并发。而且可以逐步实现未来的跨平台,因为 C#/.NET 是可以和硬件解耦的。 6park.com

但是那次尝试失败了,它叫做 Windows Vista:一个超越了摩尔定律的系统,当年的主流硬件配置跑不动。 6park.com

这是当时首席架构师盖茨同志做的决定。可能这个挫折是他仅 51 岁时就宣布退休的原因,鲍尔默则主动背了锅。 6park.com

不久谷歌用类似的架构打造了安卓 (用 Java 层和硬件解耦),头几代安卓也碰到了 Vista 类似的慢又不稳的问题,但幸运的是内存产能和台积电的工艺及时赶上了谷歌优化过的 Android Runtime。 6park.com

Vista 的失败阴影,直接导致 2008-2012 年 Windows Phone 选错了平台 (WinCE),这相当于用步兵迎战坦克。 6park.com

盖茨在多年后承认:输给安卓,是一生最大的败仗,10 年输掉 4000 亿美金。 6park.com

NT 内核加 C#/.NET 原本可以和安卓一战的,因为有大量生态可以共用,加上当时还算霸主的诺基亚。但等到 2012 年底 WP8 才决定换 NT 内核时,黄花菜都凉了。 6park.com

近年来随着硬件性能过剩和.NET Core 开源,C# 谷底反弹。除了成为 Windows 原生应用开发的皇家推荐,C# 也在一些领域取得了显著的成功:比如日中天的游戏引擎 Unity。 6park.com

四、解耦 6park.com

反例当然也有,大神拿个树枝也能当剑,中本聪用 C++ 创世了坚固的比特币。 6park.com

面向对象并不是问题,问题总出在平台或对象的耦合上。稍微复杂一点的业务系统,就会有大量的耦合。 6park.com

伟大的程序员们,其实已经写好了大量的成熟模块 (或叫标准库),用来映射现实世界。 6park.com

只是更多的普通程序员,用低质量的代码,把这些对象粘在一起。 6park.com

这些软件基本功能是可以用的,但是不稳定,而且因为匆忙粘合很难解耦。 6park.com

更大的问题是,软件映射的现实社会大多是经过抽象和简化的。这可能会带来结果的巨大偏差。 6park.com

人类社会倒是和软件对象没有本质上的区别,所以无法证伪我们是否生活在神造的计算机里。 6park.com

相亲时,你只顾看对方精心包装过的外部接口,但对其耦合过的东西一无所知。 6park.com

人类的思维也是调用对象的。你觉得对方好看,是你的审美模块给出了结果,你不会再去刻意研究她的毛孔位置或表皮细胞排列是不是合适。 6park.com

我们一旦耦合了一个模块,比如 “日本人坏” 或 “中餐最好吃”,解耦是件异常艰难的事情。 6park.com

五、悲哀 6park.com

在生命中,你还耦合了更多:父母、孩子、老板、同事、房子、微信、美团... 6park.com

如果你能在生前把它们都解耦,你将拥有一个光辉的名字:佛。 6park.com

成功的人,能让这些对象松耦合,但这是一般人不具有的能力。 6park.com

悲哀的是,那些我们固执坚持或无比珍惜的一切,在百年后都全部会自动解耦。 6park.com

只有这篇不知所云的破文章,耦合了作者的名字,穿越未来再不分离。 6park.com

来源:金捷幡 微信号:jin-jiefan

喜欢狂心中朋友的这个贴子的话, 请点这里投票,“赞”助支持!
[举报反馈]·[ 狂心中的个人频道 ]·[-->>参与评论回复]·[用户前期主贴]·[手机扫描浏览分享]·[返回网际谈兵首页]
帖子内容是网友自行贴上分享,如果您认为其中内容违规或者侵犯了您的权益,请与我们联系,我们核实后会第一时间删除。

所有跟帖:        ( 主贴楼主有权删除不文明回复,拉黑不受欢迎的用户 )


用户名:密码:[--注册ID--]

标 题:

粗体 斜体 下划线 居中 插入图片插入图片 插入Flash插入Flash动画


     图片上传  Youtube代码器  预览辅助

手机扫描进入,浏览分享更畅快!

楼主本栏目热帖推荐:

>>>>查看更多楼主社区动态...






[ 留园条例 ] [ 广告服务 ] [ 联系我们 ] [ 个人帐户 ] [ 版主申请 ] [ Contact us ]