软件开发领域的10场有意思的对抗

本贴最后更新于 3723 天前,其中的信息可能已经物是人非

  

      英文原文:10 battles raging for the hearts and minds of developers 

  这个世界是辩证统一的,正如太极所表现的那样,共存的阴阳两极既有对抗,又有融合。在现实生活中,共存事物间的对抗也是无处不在。比如,同为冷兵器的矛与盾之间的对抗,是最锋利的矛厉害还是最坚固的盾厉害?同为佳肴的鱼与熊掌之间的对抗,鱼和熊掌不可兼得,是代表海味的鱼好还是代表山珍的熊掌好?

  同样的,在软件开发领域,这样的对抗依然在上演。

  开发技术的战场之一:PHP vs.Node.js

  PHP 丝毫不受计算机科学家的待见,却深受那些只想用一丁点脑力就能完成 Web 开发的大众群体所喜爱。这群人带来了令人惊叹的框架,如 WordPress、Drupal、Joomla 等等。大部分的网站都是基于 PHP 技术所创建的。

  现在,大伙们在技术的选择上出现了分歧。年轻一代的人开始迷恋 Node.js 技术了,这是一种由 JavaScript 编写的服务器端机制。JavaScript 的出现,使程序员们发现自己写的代码既能运行在客户端也能运行在服务器端,自己再也不用学两种不同的语言了。Node.js 拥有自己的特点,但是它所提供的那些功能与最好的 PHP 堆栈所提供的其实基本一致。

  下一代程序员会接受只用 JavaScript 来简单编写的新技术么?或者他们会依靠 HTML 使代码更易于嵌入?那些喜欢 JavaScript 的人几乎肯定都会选择 Node,而那些使用 PHP 稳定堆栈如 WordPress 或 Drupal 来处理重活的人则会抵制 Node.js 风暴所带来的影响。

  开发技术的战场之二:MySQL vs.PostgreSQL

  两大开放源代码数据库无休止的战斗已经持续了快 20 年了。一方面,MySQL 因其易于安装和配置的特性在 Web 的基础工作中已经占据了大部分份额。另一方面,PostgreSQL 拥有在故障中保护数据的更好机制。现在,两者都在迅速改善自己不足之处,MySQL 提供了改进的事务处理功能,而 PostgreSQL 简化了自身的启动流程。

  两者在很久以前存在着的差异性仍然在影响着今天的战线,PostgreSQL 被认为更“可靠”而 MySQL 则被认为是更“快速”。这是一种先入为主的思想,正如当今的时髦黑客和讨厌 Oracle 的人常会选择 PostgreSQL 那样,这两个竞争对手可能还需要另一个 20 年才能改变这种思想在用户中的影响。

  开发技术的战场之三:Swift vs.Objective-C

  苹果这些年只用 Objective-C 来为其进行定制开发,这是一门干净,混合了C语言的面向对象的编程语言。但是,现在时代变了,Swift 提供了一套现代化的语法免除了在苹果平台构建代码的程序员的许多烦恼。当然,那些从小就学习了C语言的人并不介意复杂语法与多文件,但是那些由 Python、Ruby 甚至是 Java 入门的人却对此抱怨颇深。

  Swift 的整洁结构会抓住苹果开发者的心么?Python 和 Ruby 的开发者会涌向 iOS 开发领域并挤掉那些保守的 Objective-C 程序员的生存空间么? 或者这个世界会被那些 Objective-C 程序员的可靠惊人效率所征服?苹果曾公开表示这两门语言能够共存,那么新的库和特性是用 Swift 还是 Objective-C 来编写?开发者们将会通过熟悉的语言来分成不同的集群,那些喜欢 Python 或者 Java 的将会转到 Swift,而从小与C一起长大的将会坚持使用 Objective-C。

  开发技术的战场之四:Python vs.Ruby

  很久以前,对于软件来说脚本语言就像万能胶。如果你需要把大项目粘合在一起,你可以在操作系统中编写简单的脚本代码就可以完成。

  在这个过程中的某个时候,那些喜欢摆弄这些小巧语言的人们发现用它们构建大型程序也是非常有用的。当 Ruby 与 Rails 框架联姻之后,这个组合瞬间火爆了——它们把一个复杂的数据库前端简化得只有少量几段代码了。

  与此同时,Python 在科学领域建立了它的粉丝俱乐部。它被广泛运用于每个地方的实验室,伴随着统计学理论在企业界各个角落的破壳而出,尖端的 Python 被认为是获得商业领域数据科学实验的动力。

  下一代的程序员会被使用空格进行代码设计的 Python 的简洁所吸引么?Ruby 的扩张速度会超过 Rails 么?Python 的内置函数比 Ruby 的“块”更好?与那些科学家或者 Web 黑客站在同一阵线看起来是否更酷?或许是积习难改,那些网站的站长现在仍然坚持使用 Rails,而科学家们则只对 Python 的库情有独钟。

  开发技术的战场之五:SQL vs.NoSQL

  道路的一侧是你的先辈们过去就曾使用的数据库——数据很好的融入表格之中,数据库执行外部查询来与表格进行匹配并找到正确的行数。道路的另一侧是突然崛起的 NoSQL,它注重速度与并行性,当事情可能变得更糟糕的时候它会每隔一段时间发出一些小的警告,数据库将会从错误中回退并重新作出不同的操作。

  使用传统事务保护机制的传统数据库“腰带+吊带”式的处理方法是你的数据所需要的东西?或者你需要一个在计算机集群中能够有效的将负载进行均衡扩散的更快更便宜更时髦的工具?稳定性与准确性对银行业来说固然很重要的,但那些来自网络上喋喋不休的废话它也需要么?是否所有行业都需要得到数据科学家那种层次的保护?这些问题通常的答案会是:那些需要绝对稳定性的行业如银行业和航空业在处理事务时应当使用传统的 SQL 数据库,而其它那些无此特定需求的行业可以选择使用快速、简单、可扩展的 NoSQL。

  开发技术的战场之六:JavaScript vs.Dart 和 Go (或者说与谷歌本身的对抗)

  在谷歌这个地方 JavaScript 也有自己的粉丝,但是你可能还不知道它还常被其它语言不断替代实现。最早的时候,谷歌推出了 GWT (Google Web Toolkit),这是一种聪明的跨平台编译器,能够把 Java 转化成 JavaScript。但是,如果你曾经看到过 Gmail 或者谷歌其它产品的代码堆栈,你会发现它们并不完全是用 JavaScript 实现的。在稍晚的时候,谷歌创造了 Dart 和 Go。这是两种可能在未来某天在浏览器上完全取代 JavaScript 的语言。

  Dart 和 Go 在各自领域都有其独特的用处。它们修复了使用 JavaScript 和浏览器堆栈的一些主要突出但是却不被许多人在意的问题。而由于 Node.js 的原因,JavaScript 在服务器端异常火爆,人们已经不再需要其它东西了。

  为了掌握绝对的权力,谷歌将面临着一场与大批曾经学习了 JavaScript 而现在想要用它重写服务器堆栈的程序员大军之间的艰苦斗争。要战胜习惯是非常困难的,但是那些从早期就深刻体会到 Dart 和 Go 干净语法和简化模型的最佳体验者所发出的赞美将会成为大众不可忽略的声音。

  开发技术的战场之七:Chef vs.Puppet

  很久以前,公司在后台拥有很少的服务器,并且安装新的软件都非常简单。后来,随着云技术的兴起,为了保持网站的持续运转,需要将所有有价值的东西放在集群设备上。这就意味着做N件事情就会访问N个设备,彼此之间不会产生干扰。Chef 和 Puppet 是为了帮助管理员像流水线一样配置云设备而出现的两个工具。

  开发运营专家专注于 Chef,这个配置管理工具拥有一流的灵活性——能够让你用 Ruby 来编写创建设备的指令。他们说:“你能够无偿的获得 Ruby 的力量。”Puppet 也被用于集群的配置, 但是用于指定做某事的指令是由类似于 JSON 一样的语言发出的。虽然 Puppet 的几个新版本支持一点 Ruby 了,但是基础语言仍然占据着统治地位。那么,到底是为工作创建自定义语法更好呢还是给予人们完全开放、用途广泛的语言的权力(或者危险)更好?

  开发技术的战场之八:Hudson vs.Jenkins

  持续性集成是一个通过自动测试将所有全新代码部署到存储库中的想法。当这个想法获得很大成功之后,人们开始争夺它所带来的利益。

  战场的一边是 Hudson,它是 Eclipse 基金会正式项目的一部分,是由收购了 Sun 公司的 Oracle 所管理的那个分支。他们用一流的企业态度来构建企业需求使用的稳定、严肃的工具。而另一边是 Jenkins,它是原 Hudson 的另外一个分支,现在它是那些众多从很早就开始玩技术的黑客的家。Jenkins 这颗大树成长非常迅速,它的最新版本基本每个星期就会发布一次。

  Hudson 和 Jenkins 的战场可以看作是开发者世界里更大规模战场的象征,是坚定奉行谨慎测试、稳固代码的面向企业理念与更快发展、更快 Bug 修复、面向更多用户群体理念之间的对抗。

  开发技术的战场之九:MySQL vs.MariaDB

  说到由于 Oracle 收购所引发的战斗,我们不能不提到 MariaDB 与 MySQL 之间的分裂。

  当 Oracle 买下了 MySQL 后,开源的支持者们开始担心这个强大的工具会成为 Oracle 公司私有的赚钱手段。他们的担心是多余的,但这并不能阻止 MySQL 创始人之一 Monty Widenius 另起灶台。在 MariaDB 拥护者眼里,MariaDB 除了拥有与 MySQL 同样的语法和功能,还包含了一些全新特性,甚至存储引擎运行速度更快一些。

  未来的市场将会选择充满活力的新事物还是坚持选择庞大并在这些年里占据着主导地位的数据库?这个世界会钟情于矮小且衣衫褴褛的创新者还是庞大稳定而可靠的成功者?我们将拭目以待。

  开发技术的战场之十:编译语言 vs. 脚本代码

  在即时编译器和优化器面前,编译语言和脚本代码之间的区别并不明显,但是这点对程序员们来说仍然很重要。一种是代码逻辑性更强,需要反复揣摩,优化,更接近于底层机器逻辑处理的语言;另一种是开发更加直观容易,甚至可让计算机在代码在运行时修改自身代码的语言。

  前者的代表都是一些传统的语言,如C和 Java,它们都拥有精心设计的开发套件。而后者的代表都是一些结构简单的语言,如 Python、Ruby 和 JavaScript,它们能够在文本编辑器中创建并可随时放入小型运行环境中进行解译。对于解决更加复杂的问题,它们拥有混合的解决方案,如 Groovy,这是一种脚本编译混合类语言,它能够运行在 Java 虚拟机上,而它自身是一个能够进行大量实时优化的工具。编译语言与脚本语言的区别正在慢慢模糊,但是这仍然阻止不了人们对于复杂的编译程序工作是否真的值得去做的争论。

 

转自:http://news.cnblogs.com/n/518559/

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...
Vanessa
我们终此一生,就是要摆脱他人的期待,找到真正的自己。

推荐标签 标签

  • Oracle

    Oracle(甲骨文)公司,全称甲骨文股份有限公司(甲骨文软件系统有限公司),是全球最大的企业级软件公司,总部位于美国加利福尼亚州的红木滩。1989 年正式进入中国市场。2013 年,甲骨文已超越 IBM,成为继 Microsoft 后全球第二大软件公司。

    107 引用 • 127 回帖 • 342 关注
  • App

    App(应用程序,Application 的缩写)一般指手机软件。

    91 引用 • 384 回帖
  • FreeMarker

    FreeMarker 是一款好用且功能强大的 Java 模版引擎。

    23 引用 • 20 回帖 • 464 关注
  • 职场

    找到自己的位置,萌新烦恼少。

    127 引用 • 1708 回帖
  • 强迫症

    强迫症(OCD)属于焦虑障碍的一种类型,是一组以强迫思维和强迫行为为主要临床表现的神经精神疾病,其特点为有意识的强迫和反强迫并存,一些毫无意义、甚至违背自己意愿的想法或冲动反反复复侵入患者的日常生活。

    15 引用 • 161 回帖 • 2 关注
  • 数据库

    据说 99% 的性能瓶颈都在数据库。

    345 引用 • 754 回帖
  • Jenkins

    Jenkins 是一套开源的持续集成工具。它提供了非常丰富的插件,让构建、部署、自动化集成项目变得简单易用。

    54 引用 • 37 回帖
  • 持续集成

    持续集成(Continuous Integration)是一种软件开发实践,即团队开发成员经常集成他们的工作,通过每个成员每天至少集成一次,也就意味着每天可能会发生多次集成。每次集成都通过自动化的构建(包括编译,发布,自动化测试)来验证,从而尽早地发现集成错误。

    15 引用 • 7 回帖
  • RESTful

    一种软件架构设计风格而不是标准,提供了一组设计原则和约束条件,主要用于客户端和服务器交互类的软件。基于这个风格设计的软件可以更简洁,更有层次,更易于实现缓存等机制。

    30 引用 • 114 回帖 • 1 关注
  • 尊园地产

    昆明尊园房地产经纪有限公司,即:Kunming Zunyuan Property Agency Company Limited(简称“尊园地产”)于 2007 年 6 月开始筹备,2007 年 8 月 18 日正式成立,注册资本 200 万元,公司性质为股份经纪有限公司,主营业务为:代租、代售、代办产权过户、办理银行按揭、担保、抵押、评估等。

    1 引用 • 22 回帖 • 796 关注
  • Sym

    Sym 是一款用 Java 实现的现代化社区(论坛/BBS/社交网络/博客)系统平台。

    下一代的社区系统,为未来而构建

    524 引用 • 4601 回帖 • 710 关注
  • HBase

    HBase 是一个分布式的、面向列的开源数据库,该技术来源于 Fay Chang 所撰写的 Google 论文 “Bigtable:一个结构化数据的分布式存储系统”。就像 Bigtable 利用了 Google 文件系统所提供的分布式数据存储一样,HBase 在 Hadoop 之上提供了类似于 Bigtable 的能力。

    17 引用 • 6 回帖 • 66 关注
  • MongoDB

    MongoDB(来自于英文单词“Humongous”,中文含义为“庞大”)是一个基于分布式文件存储的数据库,由 C++ 语言编写。旨在为应用提供可扩展的高性能数据存储解决方案。MongoDB 是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。它支持的数据结构非常松散,是类似 JSON 的 BSON 格式,因此可以存储比较复杂的数据类型。

    91 引用 • 59 回帖 • 5 关注
  • 代码片段

    代码片段分为 CSS 与 JS 两种代码,添加在 [设置 - 外观 - 代码片段] 中,这些代码会在思源笔记加载时自动执行,用于改善笔记的样式或功能。

    用户在该标签下分享代码片段时需在帖子标题前添加 [css] [js] 用于区分代码片段类型。

    188 引用 • 1333 回帖
  • Anytype
    3 引用 • 31 回帖 • 26 关注
  • Ant-Design

    Ant Design 是服务于企业级产品的设计体系,基于确定和自然的设计价值观上的模块化解决方案,让设计者和开发者专注于更好的用户体验。

    17 引用 • 23 回帖 • 3 关注
  • Thymeleaf

    Thymeleaf 是一款用于渲染 XML/XHTML/HTML5 内容的模板引擎。类似 Velocity、 FreeMarker 等,它也可以轻易的与 Spring 等 Web 框架进行集成作为 Web 应用的模板引擎。与其它模板引擎相比,Thymeleaf 最大的特点是能够直接在浏览器中打开并正确显示模板页面,而不需要启动整个 Web 应用。

    11 引用 • 19 回帖 • 395 关注
  • MyBatis

    MyBatis 本是 Apache 软件基金会 的一个开源项目 iBatis,2010 年这个项目由 Apache 软件基金会迁移到了 google code,并且改名为 MyBatis ,2013 年 11 月再次迁移到了 GitHub。

    173 引用 • 414 回帖 • 363 关注
  • Ruby

    Ruby 是一种开源的面向对象程序设计的服务器端脚本语言,在 20 世纪 90 年代中期由日本的松本行弘(まつもとゆきひろ/Yukihiro Matsumoto)设计并开发。在 Ruby 社区,松本也被称为马茨(Matz)。

    7 引用 • 31 回帖 • 261 关注
  • 小薇

    小薇是一个用 Java 写的 QQ 聊天机器人 Web 服务,可以用于社群互动。

    由于 Smart QQ 从 2019 年 1 月 1 日起停止服务,所以该项目也已经停止维护了!

    35 引用 • 468 回帖 • 761 关注
  • 阿里巴巴

    阿里巴巴网络技术有限公司(简称:阿里巴巴集团)是以曾担任英语教师的马云为首的 18 人,于 1999 年在中国杭州创立,他们相信互联网能够创造公平的竞争环境,让小企业通过创新与科技扩展业务,并在参与国内或全球市场竞争时处于更有利的位置。

    43 引用 • 221 回帖 • 59 关注
  • 书籍

    宋真宗赵恒曾经说过:“书中自有黄金屋,书中自有颜如玉。”

    82 引用 • 409 回帖 • 1 关注
  • LeetCode

    LeetCode(力扣)是一个全球极客挚爱的高质量技术成长平台,想要学习和提升专业能力从这里开始,充足技术干货等你来啃,轻松拿下 Dream Offer!

    209 引用 • 72 回帖 • 1 关注
  • Telegram

    Telegram 是一个非盈利性、基于云端的即时消息服务。它提供了支持各大操作系统平台的开源的客户端,也提供了很多强大的 APIs 给开发者创建自己的客户端和机器人。

    5 引用 • 35 回帖 • 1 关注
  • Scala

    Scala 是一门多范式的编程语言,集成面向对象编程和函数式编程的各种特性。

    13 引用 • 11 回帖 • 159 关注
  • Node.js

    Node.js 是一个基于 Chrome JavaScript 运行时建立的平台, 用于方便地搭建响应速度快、易于扩展的网络应用。Node.js 使用事件驱动, 非阻塞 I/O 模型而得以轻量和高效。

    139 引用 • 269 回帖 • 1 关注
  • Dubbo

    Dubbo 是一个分布式服务框架,致力于提供高性能和透明化的 RPC 远程服务调用方案,是 [阿里巴巴] SOA 服务化治理方案的核心框架,每天为 2,000+ 个服务提供 3,000,000,000+ 次访问量支持,并被广泛应用于阿里巴巴集团的各成员站点。

    60 引用 • 82 回帖 • 615 关注