怎样解决编程语言之间的差异性问题? -买球官网平台

5顶
0踩

毫无疑问,不同的编程语言间存在着很多差异性。那么对于这种差异性开发者应如何解决?本文就来一探究竟。

以下为译文:

我一直在告诉别人:“编程非常了不起。”在你有任何想法的时候,都可以编写软件,然后愿望就实现了。这很真实。与建立物理的东西不同,首先你需要建立整个工厂,而软件的扩张相对非常容易。你可以找到所有已经编译好的组件,而且是免费的,拿来就可以用。建立好一段代码后,就可以重复使用无数次,而无需花钱。听起来很厉害的样子。

但有时候不是这样的。编程带给人的惊喜只是暂时的。在建立了很多代码以后,在写代码的过程中你会不断遇到让人迷惑的错误。一旦你习惯了特定语言和框架的模式后,一旦你需要第二种天性去掌握所选语言中非自然的语法时,编程的伟大之处就不复存在了。

更别提我们有无数种不同的编程语言。每当开发人员面对特殊语言的语法而深感沮丧时,他们都会想“为什么我们不能创建一种新的语言改正这个问题呢?”有些人还真的这么做了,很幸运的是自然选择已经淘汰了很多很差的语言(有时也有意外,比如至今php还存在)。一旦一门新的语言开始在一群开发者中流行起来,那么恭喜你 ,现在又出现了一个新的开发者社区,他们互相合作,努力让这门特殊的语言发展壮大。

每一种新语言的诞生所带来的创新,都能造福我们每一个人。但是有时也有不利的一面。有些人可能写了一些非常有用的开源javascript库,但是从事python的开发者却完全没法用。他们不得不自己写一个python版本的函数库,或者用javascript重写所有代码。再想想当前有多少种语言和框架。如果你不觉得这很荒谬的话,那只能说明或许你在软件开发这一行太长时间,已经习以为常了。

语言都包含些什么?

各种编程语言都在以下三个方面上有着很大的不同:语法、语义和标准库。

没错,我知道,我过于简化它们了,但是听我给你解释。

1. 语法

如果不遵循语法,那么你会在编辑器中看到各种弯弯曲曲的红线,而且你的代码也无法通过编译器或解释器。

javascript使用大括号,布尔型使用小写的true和false,用//表示行注释。
function dosomething() {
  a = true;
  if (a) {
    ... // do something.
  }
}

python用缩进,布尔型用首字母大写的true和false表示,用#表示行注释。
def dosomething():
  a = true
  if a:
    ... # do something.

haskell又有完全不同的语法:
dosomething :: io ()
dosomething = do
  let a = true
  if a
    then ... -- do something.
    else return ()

2.语义

所有编程语言都有大多数相同的特征:变量赋值、数字相加、字符串操作、调用函数、等等。

然而,每种语言都有特殊的思想,以特定的方式运行。可以将它们划分成不同的模式(命令式、面向对象、函数式),但是即便是两个相同模式的编程语言在细节上也是完全不同的。

在“声明类”,“调用函数”,或“定义参数的类型”时,你定义了程序的语义。有些语言遵循这样一套规则,而其他的遵循别的规则。比如:c 中声明的类可以延伸到多个类。当你使用“ ”将数字和字符串加到一起的时候,根据语言的语义会得出不同的结果。一些编程语言会因为类型不匹配而导致编译失败,但是有些编程语言会自动将数字转换成十进制的字符串。

语法与语义的关系就相当于用单词(语法)来表达想法(语义)。你可以通过语言的语法来表达语义。

3.标准库

最后,每种语言都有各自的软件包,我们称之为“标准库”。

在python中,你可以调用如下函数:
  • print():在控制台输出信息
  • len():返回数组的长度
  • 以及各种实用的模块,例如:json,threading,等等
在javascript中,你可以使用console.log()代替print(),可以访问object、array等类。

标准库是一门语言中重要的组成部分。它可以为语言带来活力,没有标准库,你无法简单地做出任何东西。

很讽刺的是,并没有“标准的标准库”。每个标准库基本上都不同于其他库:一些库只提供最低限度的方法,而有些库则提供非常广泛的函数,所以开发人员基本上不需要依赖任何第三方库。

基本的想法

以上我们介绍了一门语言的构成,接下来我有一个基本的想法:我们是否可以找到一种方法清晰地分割语法、语义和标准库呢?我们又如何实现这一想法呢?

第一步:只有程序员关心语法

我想解决的第一个问题就是语法。编译器和解释器拥有更加有效的方式表现代码,我们称之为抽象语法树。我们用代码描述的内容最终可以用如下抽象语法树表示:

图:欧几里得算法的抽象语法树

如果仔细观察,你会发现上述语法树可能来自多个语言。是python?是javascript?还是c ?这都无所谓:所有这些语言都拥有同一个语法树。

当然,现实的例子会更加复杂。这就是为什么我们用文本写代码的原因:更加紧凑,更加易于书写,还有更加易于阅读(有人可能有不同的看法)。从编程诞生的第一天,我们采用的就是这种方法,很少有人对此质疑。

对于一个更加现实的例子来说,抽象语法树会描述所选语言的语义(例如:类的定义)。但是拥有类似语义的语言之间还是可以共享同一个抽象语法树,并可以扩展到一定范围。这非常实用,因为你可以自动转化部分代码。

所以,我们可以把语法想象成抽象语法树之上的人类思维。代码可能并不会以文本的形式存储在任何地方,仅在文本编辑器内。如果你想在特殊的语言上使用不同的语法,也完全可以。这不会影响到别人。

我其实有点惊讶怎么没有一种工具可以将代码从一种语言转换成另一种语言,这完全可行啊。我猜肯定有人试过,但是放弃了,因为如果不将整个标准库转换过去的话是没有实用性的。很明显,我也在做这方面的尝试。

第二步. 将标准库抽象成api

api是一个非常高明的概念。每个软件都可以通过api与其他软件沟通。移动端的应用可以通过api与服务器交流。服务器可以通过api与数据库交流。每个人都可以通过api与他人对话。这是一件很酷的事情。

为什么我要在这里讨论api?因为这正是我们所需要的。api是语言的媒介。它们是一套语义,可以描述一个特殊代码模块对外提供的功能。无论是函数库,http服务器,或是别的。

声明api的方式多种多样。可以是npm上的javascript模块,并在readme文件内提供api文档。也可以是代码中明确声明的api,比如typescript模块。也有可能并没有api的声明,也没有清晰的文档。

但是重要的是:api声明了代码模块的”对外接口“,你可以用其他语言重写模块内部的代码,但api不会发生改变。这就是api的魅力所在。虽然编程语言一团糟,但是api很酷。

前面我们提到了标准库,并说了各个语言都拥有完全不同的标准库。如果我们能想个办法将标准库抽象出来,做成干净利落的api,那么我们就可以解决这个问题。虽然在语义上,调用print("hello")与java调用system.out.println("hello")不同,但是其实它们可以是同一个api。

我们有两种方法可以解决这个问题。要么我们让大家都不要再使用标准库了,转而使用我们的“api层”。或者我们可以让计算机自动推断你使用的代码。我并不看好“说服大家改变他们的方式”,所以我会选择后一种方法。

我们不用为编程语言的标准库中的每个函数都提供api。一般我们只可能用到标准库中的几个函数。我们可以自动将这些代码从一种语言转换到另一种语言。然后,我们只需要每个开发都用这些api替换具体的标准库的调用。不用担心,计算机依然需要你,至少现在需要。

第三步:把所有东西都做成api

现在我们有了干净的代码模块定义的纯粹的语义,并将与标准库的交互抽象成了api。

下一步做什么?创建api。

现今的代码库有多个文件构成,彼此之间通过“import语句”互相引用。这对于我们来说很便利,但是这也意味着我们需要在脑海中勾画代码库的结构。任何一个地方发生小的变化,都可能在不经意期间给别的地方带来破坏性的影响,尤其是如果我们没有做好自动测试的话。而且,代码库会不断增长,而编译的时间会逐渐加长。

也许有更好的方法解决这个问题。比如模块化就是个好办法。

我之前写过关于模块化的文章(点击这里查看:https://medium.com/@fwouts/the-zenc-master-plan-c693bf3b265e),基本上来说:每段独立的代码都应该抽象成api。我称之为模块。你无需在意一个具体的模块使用什么语言编写的。在写模块的时候,你不用导入这些文件。实际上,这时文件已不复存在。你可以直接使用api,它们会自动加载这些功能。

模块有什么好处?
  • 可以鼓励大家考虑设计:首先你需要设计api
  • 可以降低认知的开销:你仅需要“填空”
  • 简化测试:你只需测试api,并可以模拟所有的依赖性
  • 世界会变得更加美好:没有了语言之间的壁垒,没有了巨大的代码库;程序员更加快乐,客户更加快乐
第四步:尽情享受

我不确定第三步之后会发生什么,但是我觉得所有人都会很满意。
  • 大小: 341.7 kb
  • 大小: 91.3 kb
来自:
5
0
评论 共 8 条 请登录后发表评论
8 楼 homepeople 2021-08-22 22:43
所有的语言学习大致就2步,数据结构 算法,其他的都是浮云
7 楼 homepeople 2021-08-22 22:41
数据结构都不谈,现在的程序员不知道都学得什么东西
6 楼 bzhao 2020-08-04 15:35
想法很好,现实很残酷, 很明显没有办法解决成就感的问题,
5 楼 xingqi1058 2019-08-22 15:27
xingqi1058 写道
xingqi1058 写道
ss

说的很好
4 楼 xingqi1058 2019-08-22 15:27
xingqi1058 写道
ss
3 楼 xingqi1058 2019-08-22 15:27
2 楼 xingqi1058 2019-08-22 15:22
[img] [/img]
1 楼 aa87963014 2018-07-24 09:42
非常赞同,现在的语言太多了语法又差异太大增加无谓的学习成本很恶心

发表评论

您还没有登录,请您登录后再发表评论

相关推荐

  • 由于这些语言之间的差异(在设计的内部和外部),对问题空间的评估导致选择了不同的语言。 然后通过多种语言解决跨域问题。 在这种情况下,单个gpl不能证明是通用的解决整个问题空间的方法。 unilang的立场是,不同...

  • 浏览各大编程相关的网站, 总是能看到有关于编程语言的争论, 这些争论使得想要学习编程的人变得疑惑。 总会让人陷入到底什么是最好的编程语言, 我该学什么, 这样的疑问中。 我曾经也陷入过这样的疑惑中, 入行做...

  • 计算机语言、编程语言、语言处理器介绍

  • 我一直在告诉别人:“编程非常了不起。”在你有任何想法的时候,都可以编写软件,然后愿望就实现了。这很真实。与建立物理的东西不同,首先你需要建立整个工厂,而软件的扩张相对非常容易。你可以找到所有已经编译好...

  • 选自thenewstack作者:david cassel机器之心编译编辑:小舟、张倩...当能耗也成为了一个重要指标,我们要怎么选择编程语言?2017 年,由 6 名葡萄牙研究者组成的团队决定对这一问题进行调查并发表了一篇名为《energy...

  • 很大程度上是由于编程语言和人类语言(学名叫做自然语言)之间存在着很大的思维差异。   为了帮助大家理解,先举个栗子,老婆对老公发信息说:下班买几个苹果回来,如果看到西瓜,就买一个回来。不知道大家看到这句...

  • 今天想和大家分享的内容是和我们手机上app相关的,它们都是用什么编程语言写的呢?主要针对两大移动端:android和ios,我们就不多说了,下面我们从另一个角度进行分类。01第一类:针对单...

  • shell程序的问题在于程序超过百行之后扩展性差,并且比其他语言的运行速度慢很多。 2、c和c 语言 极其重视性能的时候使用,它们有许多细节需要自己处理,处理不当就会导致程序崩溃和其他难解决的问题。而c 和c...

  • 文章目录前言并发程序幕后的故事源头之一:缓存导致的可见性问题源头之二:线程切换带来的原子性问题源头之三:编译优化带来的有序性问题 前言 如果你细心观察的话,你会发现,不管是哪一门编程语言,并发类的知识...

  • 人工智能是一个很广阔的领域,很多编程语言都可以用于人工智能开发,所以很难说人工智能必须用哪一种语言来开发。选择多也意味着会有优劣之分,并不是每种编程语言都能够为开发人员节省时间及精力。所以我们整理了5...

  • 作者 | nibble stew 责编 | 弯月出品 | csdn(id:csdnnews)自从编程语言诞生以来,人们常常就哪种语言速度最快的问题争论不休。无论是严肃的科学研究...

  • 使用稳定的选择器会让 ui 自动化测试更简单:我们可以使用嵌套 api 作为一种稳定的方式来和 dom 挂钩,而不用管它的布局和层次结构是怎么样的。form > (fieldsets) > element 这样的层次结构可以作为文档的交互式...

  • 技术是通过编程语言来实现的,技术领域中有600多种编程语言。编程语言的命令和识别每年都在变化。此外,新的编程语言还具有引人注目的特性和功能。 为了促进软件开发服务和web应用程序的需求,以下急需提及的十大最...

  • 其中可以起到的作用就是提升企业仓库管理水平,为企业创造更多的可观价值,不过的wms系统有专业和普通之分,很多企业在购买之前都想要了解一下两者之间差异明显吗,到底都有什么样子的差异性,下面我们来具体看看...

  • 选择一门语言确定你感兴趣的领域你可以开始学习任何编程语言(尽管其中一些被描述地比其他的更加“易学”),你得去问自己自己想用通过学习这门语言完成什么样的工作。这将会帮助你确定你应该追求的编程方式并且提供...

  • 手头有了问题,他可以用两分钟浏览一下这语言的手册,看看这语言大概长什么样。 然后,他直接拿起一段例子代码来开始修改捣鼓,想法把这代码改成自己正想解决的问题。在这个简短的过程中,他很快的掌握了这个语言...

  • 。。。

  • 。。。

global site tag (gtag.js) - google analytics