博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
编程语言不仅仅是工具而已
阅读量:6202 次
发布时间:2019-06-21

本文共 1237 字,大约阅读时间需要 4 分钟。

我绝对的认可懂得多种编程语言的价值,也认为“用正确的工具干活儿”是个好思想。但在编程工作中,人们对这个概念有个误解,我认为需要在这里指出一下。但请记住,对这个误解的诠释并不是来否定这个思想的。

多语言电影

让我从一个古怪的类比开始:假设这有一个电影,是关于一个政治阴谋,涉及到一系列复杂的国际冒险,冲突波及到7、8个国家。每个演员都说着他们本地的语 言,没有字幕。谁能看懂这个阴谋的情节?恐怕只有少数几个懂得多语言的制片人能欣赏的了这个电影。我们大部分人都不会去看它。

多语言编程

我们的上一个Web应用项目里使用了6、7种的编程语言(Groovy, Java, HTML, CSS, SQL, Ant)。如果我们感觉需要的话,还可以轻松的再增加更多的语言。再增加Clojure, Scala 或 Ruby/JRuby 并不会觉得不合适。一个懂得多种语言并有能力在多种语言间切换到程序员就被称作“多语言程序员”。

造成多语言项目产生的一个主要理由通常是“使用正确的工具干活儿”的概念。而这个“活儿”通常指的是一个大项目里的一些小任务,比如编译项目,访问数据库, 实现永不定型的业务逻辑。对于每个子任务,都有某个语言能够更出色的完成。除了人们对这种多语言的做法造成的隐藏成本存在争议外,还有一个对于“工具”这 个词的误解需要注意。

编程语言不是工具

如 果你的工具碰巧是一种编程语言,那你生产的源代码将和你的工具融合到一起。没有这个工具,你的产品完全不能运行。如果你认为编译后的二进制代码是“产 品”,你将没有可能针对它做“需求变更”,这是程序员最初可能会有的一个错误概念。很显然,程序员的生产的产品是“源代码”。编程语言并不是扮演工具的角色,从软件的性质上看,它应该是材料。工具可以扔掉,材料构成主体。

编程语言是产品材料

因为源代码依附于它的编程语言,它们是一个概念上的合体。所以,我建议,当我们在谈论编程语言时,应该改成“使用正确的材料来干活儿”的说法。相比起选择 是使用飞利浦的螺丝刀还是三菱的改锥这样的问题,我们修改后的说法会对编程语言的选择起到更深远的意义。材料需要持久的耐用,而工具大部分时间是丢在一 边。

但同时也是工具

在上面提到的我们做过的Web应用项目中,我们使用了很多工具。Grails是我们的框架,Jetty是我们的Web容 器,Spring Framework提供了强大的服务,我们用IDEA把它们结合到一起。我们可以轻松的用Tomcat替换Jetty,或用Eclipse替换IDEA。 工具需要可替换,甚至是一次性的。

总结

“用正确的工具干活儿”这话并不能简单的应用到编程语言上,因为它们不是工具,而是材料。这就是为什么在一个项目中大量使用多语言是危险的。它很容易让项目变成一个混乱的“复合板“项目。

更多集合请登录e良师益友网。

转载于:https://www.cnblogs.com/yuguotianqing/p/4052150.html

你可能感兴趣的文章
Orcal学习
查看>>
AttributeError: 'str' object has no attribute 'decode'
查看>>
oracle 存储过程的一个小问题
查看>>
采用个hook技术对writefile函数进行拦截
查看>>
教程-最全ASCII 码对照表
查看>>
服务器重启后导致访问ArcServer地图服务须登录
查看>>
分享一篇通俗易懂的js闭包文章
查看>>
QuartzNet使用
查看>>
CreateToolhelp32Snapshot
查看>>
EM算法
查看>>
3月5日学习内容整理:django中的CBV和FBV,以及csrf_token的实现方法以及在CBV中的应用...
查看>>
看看你那张熬完夜的脸
查看>>
服务器上后台下载的一些技巧
查看>>
Centos7 使用Dockerfile 制作自己的Dotnetcore程序镜像
查看>>
实验报告三
查看>>
Linux Shell
查看>>
软件项目功能测试框架(转载自51Testing软件测试)
查看>>
springMVC-数据传递
查看>>
LIS(最长上升子序列)与LCS(最长公共子序列)
查看>>
CentOS 6.3下Samba服务器的安装与配置(转)
查看>>