谁我们将会很杀死 Java

Java最流行的编程语言之一

2017年9月的TIOBE指數将Java列为当月较为流行的语言其实,它已经名列前三甲很多年了

不说这些结果是如何产生的,亦或者这结果是否反映了现实世界中的凊况我们不能否认的是,Java在多个环境中仍然是一种流行语言

但是,Java总有一天会死世无定事,没有什么可以天长地久

编程语言死亡嘚真正定义是没有人再使用它——但这样的情况很难发生。即使是老朽且不被广泛使用的语言(例如你是否听说过Modula-3?)仍然在被使用、维护,或者至少会演变成其他的东西

当然,这是一个渐变的过程怎么发生的方法不定。从实际出发假设编程语言在它不再被用于噺项目时,就意味着它的死亡但是它可能依然存活在许多遗留项目上(COBOL就是一个完美的例子)。

最终这结局也将降临到Java头上那么谁会殺死它?

可能杀死Java的选项

在任何语言中你都可以搞得一团乱当然,在某些语言中比其他语言更容易导致混乱——例如,在动态类型语訁中我们可以随时更改变量的类型——但是我们在Java中没有这个问题。

此外在Java社区中很多人采用的良好实践,比如设计模式和TDD有助于峩们制作更好的软件。

所以让我们来探讨另一个选项

Java是面向对象的语言。如果其他(新的)范式接管了怎么办如果面向对象的编程变嘚过时了怎么办?

好吧这可能性并不大——基本原理已经有很长一段时间没有真正改变过了。诸如结构化功能性和面向对象编程的重夶创新发生在20世纪50年代,60年代以及甚至70年代但从那以后,没有什么举足轻重的事发生

但是,在过去十年中却有很多新的语言问世,這些语言有着现代的语法以及新功能的框架

那么,没有现代语法和新的功能是否会导致Java的死亡呢

以类似的方式,虽然Java不是一个功能齐铨的语言但是由于有Vavr这样的库,我们可以使Java更加功能化

我的意思是,Java缺少的某些东西有人会通过创建(框架,工具规范,无论什麼)来填补这个空白

那么Java会不会因为另一种编程语言而死亡呢?

我们可以在后台使用Node.js类似于移动设备上的React Native或Ionic,我们甚至不必提及在前端的所有竞争选项

但是,至少在企业软件中我没有看到JavaScript将要替代Java的趋势。JavaScript在企业领域中没有取得成功的框架或工具它也没有与Java虚拟機(JVM)相当的东西,Java虚拟机(JVM)依然是大型和关键任务软件的首选平台

Kotlin语言首次出现在2011年,并且最近Google宣布在Android上对Kotlin提供一流的支持Kotlin正在逐渐被知名公司采用,并且不局限于在这些公司的Android app上

除了现代化的功能,Kotlin也是一种开放源代码的语言它由一家生产最佳java ide的公司提供支歭。

所以如果你问我的话,我的回答是是的,Kotlin看起来像是(在遥远的未来)替代Java的一个很好的候选者

当然,Java也可能被一种或多种语訁所替代

我不确定,而且我敢说现在也没有人知道这个问题的答案

我所能确定的是,没有任何语言能够自主地杀死Java不借助任何外力,就此而言

能够杀死Java的刀子在于它无法满足市场的需求。

编程语言是构建解决计算机问题的应用程序的工具如果某编程语言提供抽象、模型、工具和框架,使你可以更有效率或创建比Java更高效的代码你会选择哪种语言呢?

即使是在Java版本之间如果让你在Java 1.4和Java 9之间进行选择,那么你会选择Java 1.4吗你会放弃用lambdas或泛型工作的机会吗?我不这么认为你会需要较新版本的功能。

在这些年来由于已检查异常、内部类、getter和setter等等方面,Java被认为是一种冗长又笨拙的语言直到Java 7(有些人认为是Java 8)才开始好转。

然而Java 7于2011年发布,比Java 1.4(2002年发布)晚了九年在这个時代,这是不能接受的并且可能会导致恶性循环。

仔细查看TIOBE页面上的Java图表尽管Java大多数时候位居前三,但有明显的下降趋势表明它正茬失去市场份额。这种趋势在所有语言中都很普遍最可能的原因是编程语言的数量在不断增加,应用程序越来越多地被以多种语言编写因此,竞争比以往任何时候都要激烈

如果我们认为其他语言比这种语言更好,那么它就不再受欢迎我们也不会将这种语言教给新一玳的开发人员。

新的教程、课程和书籍将不会再被创造

社区中的宝贵成员将被其他技术吸引走。

该语言将不会用于新的环境

将导致减尐语言的流行度。

如何减缓Java的衰退

Mark ReinholdOracle Java平台组首席架构师,提出的新的六个月发布计划是向前推进Java并迈向未来的重大一步。用他的话说(僦特征驱动的版本):

这种方法可以在早期采用者进行彻底的检查和测试后以高水平的质量提供大的新功能。然而不足之处在于,较尛的API、语言和JVM功能只有在大功能准备就绪时才能实现这是在本世纪之交前后几十年时间里达成的一个可接受的折中方案,当时Java仅与几个鉯类似的步伐演进的平台竞争然而,如今Java在与许多以更快速度发展的平台一起竞争。
最后一段话很多都是事实

但是,这不仅仅是Oracle的笁作社区也必须保护Java。

不要傲慢(不要认为Java太大而不会失败)
促进良好的开发实践方法
继续发布超棒的框架、工具等
帮助教学和推广Java语訁
在新环境中尝试Java
否则Java如果无法跟上时代的步伐,那么最终将会被后浪拍死在沙滩上

}

经常有客户询问这样的问题:在垺务器上的Java进程或应用服务器进程不知道怎么回事被杀死或退出了并且发生的概率很低,3天才发生一次能告诉怎样找到原因吗?如果伱在使用Solaris10那么可以使用下面的方法来查找Java进程退出的原因:
如果是Java进程不知道什么原因退出或被杀死,想要分析具体原因一般来说分丅面几步:

1 拿到Java应用程序的日志文件。
一般来说日志文件中会有很应用相关的错误信息Java进程异常退出的原因最有可能就是应用程序本身嘚问题。因此检查Java应用程序的日志文件可能是最快定位到错误的方法

2 查找JVM的致命错误日志
如果应用程序日志文件中没有发现什么线索。那么还可以查看 JVM的致命错误日志有些致命的错误,比如JNI或虚拟机本身产生的错误可能使得Java应用程序来不及写日志就退出了。这时候可鉯查一个以 “hs_err_pid” 开头的日志名例如hs_err_pid1125.log,其中1125是进程号这个文件中也记录了一些宝贵的信息来提供一些线索,特别是Java自身的一些Bug这个文件一般为于当前的工作目录中。用户可以用find命令自己搜索到

作为被操作系统所调度的进程,Java进程也会在不同的信号下产生Core Dump文件例如Sig_ill和Seg_segv。这些非常严重的错误的确会使得Java虚拟机根本来不及产生任何日志就宕了拿到core dump文件就可以使用很多工具来分析具体原因了,例如jmap, jstack等等都鈳以友好的进行Java进程的Core文件的分析一般来说,Core文件也放到进程的当前工作目录用户可以用find命令搜索 “core”。另外可以用coreadm来预先指定core文件存放的地方以及文件名的格式例如:coreadm -g /var/core/core.%f.%p.%t

4使用Dtrace查找“是谁杀死了Java进程”
但是,有很多情况进程被杀死的原因很复杂。有可能被别的进程以外杀掉或被一些脚本不小心kill掉,或者被管理员(或入侵者kill -9)处理掉这些情况都不会产生日志文件和core dump文件。这些情况很难跟踪但如果昰Solaris10下,可以使用下面的Dtrace脚本来确定“是谁杀死了Java进程”

}

  Java 是这个星球上最为流行的编程语言之一但这方面的竞争正愈演愈烈。下面我们将讲述 Java 可能遭遇滑铁卢的地方以及可以做些什么来预防它的衰退。

  2017 年 9 月的 将 Java 列為当月较为流行的语言其实,它已经名列前三甲很多年了

  将 Java 列为继 Javascript 和 SQL 之后第三常用的编程语言(实际上,过去四年它都保持着这洺次)

  不说这些结果是如何产生的,亦或者这结果是否反映了现实世界中的情况我们不能否认的是,Java 在多个环境中仍然是一种流荇语言

  但是,Java 总有一天会死世无定事,没有什么可以天长地久

  编程语言死亡的真正定义是没有人再使用它——但这样的情況很难发生。即使是老朽且不被广泛使用的语言(例如你是否听说过 Modula-3?)仍然在被使用、维护,或者至少会演变成其他的东西

  當然,这是一个渐变的过程怎么发生的方法不定。从实际出发假设编程语言在它不再被用于新项目时,就意味着它的死亡但是它可能依然存活在许多遗留项目上(COBOL 就是一个完美的例子)。

  最终这结局也将降临到 Java 头上那么谁会杀死它?

  让我们来分析选项

被殺的原因是,它太容易造成混乱并且它的傲慢自大会导致不专业的实践方法,如缺乏测试驱动开发(TDD)

  在任何语言中你都可以搞嘚一团乱。当然在某些语言中,比其他语言更容易导致混乱——例如在动态类型语言中,我们可以随时更改变量的类型——但是我们茬 Java 中没有这个问题

  此外,在 Java 社区中很多人采用的良好实践比如设计模式和 TDD,有助于我们制作更好的软件

  所以让我们来探讨叧一个选项。

  Java 是面向对象的语言如果其他(新的)范式接管了怎么办?如果面向对象的编程变得过时了怎么办

  好吧,这可能性并不大——基本原理已经有很长一段时间没有真正改变过了诸如结构化,功能性和面向对象编程的重大创新发生在 20 世纪 50 年代60 年代以忣甚至 70 年代,但从那以后没有什么举足轻重的事发生。

  但是在过去十年中,却有很多新的语言问世这些语言有着现代的语法以忣新功能的框架。

  那么没有现代语法和新的功能是否会导致 Java 的死亡呢?

  不我不这么认为。

  以类似的方式虽然 Java 不是一个功能齐全的语言,但是由于有 Vavr 这样的库我们可以使 Java 更加功能化。

  我的意思是Java 缺少的某些东西,有人会通过创建(框架工具,规范无论什么)来填补这个空白。

  那么 Java 会不会因为另一种编程语言而死亡呢

  我们可以在后台使用 Node.js,类似于移动设备上的 React Native 或 Ionic我們甚至不必提及在前端的所有竞争选项。

  但是至少在企业软件中,我没有看到 JavaScript 将要替代 Java 的趋势JavaScript 在企业领域中没有取得成功的框架戓工具。它也没有与 Java 虚拟机(JVM)相当的东西Java 虚拟机(JVM)依然是大型和关键任务软件的首选平台。

  除了现代化的功能Kotlin 也是一种开放源代码的语言,它由一家生产最佳  的公司提供支持

  所以,如果你问我的话我的回答是,是的Kotlin 看起来像是(在遥远的未来)替代 Java 嘚一个很好的候选者。

  当然Java 也可能被一种或多种语言所替代。

  我不确定而且我敢说现在也没有人知道这个问题的答案。

  峩所能确定的是没有任何语言能够自主地杀死 Java。不借助任何外力就此而言。

  能够杀死 Java 的刀子在于它无法满足市场的需求

  编程语言是构建解决计算机问题的应用程序的工具。如果某编程语言提供抽象、模型、工具和框架使你可以更有效率或创建比 Java 更高效的代碼,你会选择哪种语言呢

  即使是在 Java 版本之间,如果让你在 Java 1.4 和 Java 9 之间进行选择那么你会选择 Java 1.4 吗?你会放弃用 lambdas 或泛型工作的机会吗我鈈这么认为。你会需要较新版本的功能

  在这些年来,由于已检查异常、内部类、getter 和 setter 等等方面Java 被认为是一种冗长又笨拙的语言。直箌 Java 7(有些人认为是 Java 8)才开始好转

  然而,Java 7 于 2011 年发布比 Java 1.4(2002 年发布)晚了九年。在这个时代这是不能接受的,并且可能会导致恶性循環

  仔细查看 TIOBE 页面上的 Java 图表。尽管 Java 大多数时候位居前三但有明显的下降趋势,表明它正在失去市场份额这种趋势在所有语言中都佷普遍。最可能的原因是编程语言的数量在不断增加应用程序越来越多地被以多种语言编写。因此竞争比以往任何时候都要激烈。

  如果我们认为其他语言比这种语言更好那么它就不再受欢迎,我们也不会将这种语言教给新一代的开发人员

  新的教程、课程和書籍将不会再被创造。

  社区中的宝贵成员将被其他技术吸引走

  该语言将不会用于新的环境。

  将导致减少语言的流行度

  ,Oracle Java 平台组首席架构师提出的新的六个月发布计划,是向前推进 Java 并迈向未来的重大一步用他的话说(就特征驱动的版本):

这种方法鈳以在早期采用者进行彻底的检查和测试后,以高水平的质量提供大的新功能然而,不足之处在于较小的 API、语言和 JVM 功能只有在大功能准备就绪时才能实现。

这是在本世纪之交前后几十年时间里达成的一个可接受的折中方案当时 Java 仅与几个以类似的步伐演进的平台竞争。嘫而如今,Java 在与许多以更快速度发展的平台一起竞争

  最后一段话很多都是事实。

  但是这不仅仅是 Oracle 的工作。社区也必须保护 Java

  • 不要傲慢(不要认为 Java 太大而不会失败)
  • 促进良好的开发实践方法
  • 继续发布超棒的框架、工具等
  • 帮助教学和推广 Java 语言
  • 在新环境中尝试 Java

  否则,Java 如果无法跟上时代的步伐那么最终将会被后浪拍死在沙滩上。

}

我要回帖

更多关于 我们将会很 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信