Java已经存在了二十多年,是程序员最喜欢、使用最广泛的编程语言之一。如果我们查看编程语言、数据库和操作系统的应用范围,你会发现在过去的几年里似乎并没有什么变化。Java让程序员又爱又恨!
人们选择使用Java的原因有很多个,我们先来看看最常见的几个:
· 简单性:Java为程序员和最红用户提供了最简单的体验,与其他编程语言相比这是Java最大的优势之一。Java消除了指针的意义,相对于C++的难度大大降低。
· 便携性:Java能够借助应用程序最任何软件和平台上运行。
· 便利性:Java具有堆栈提供系统的特性,可以帮助统计数据快速恢复。与其他web开发语言不同,Java拥有自动垃圾回收和内存分布功能。
· 分布式:Java平台具有良好的网络能力。这就意味着在Java上进行交互是非正式的,而编写网络应用程序的感觉就像是接收和发送文件。
· 安全性:Java的安全性是大众认可的。Java开发公司可以下载任何不受信任的文件,应用程序可以安全可靠的使用这些非安全性代码。
Java在大数据和互联网中的作用
在过去几年中,大数据和物联网在企业中只能算个流行词。其实这些概念存在的时间远比我第一次听到它的时间要长久,近些年技术的飞速发展,大数据和互联网技术也在不断成熟。大数据和互联网的关系相信大家都能说出一二:“物联网是感官,大数据是燃料,人工智能是实现智能连接未来世界的大脑。”
数以百万计的设备联网导致了大量数据的大量涌入。现有的大数据技术需要增强,以便对数据有效的进行存储、管理和价值提取。随着生产的数据持续增长,分析需求也会不断增加,而Java开发可能将是大数据和物联网的可预见的未来。
大量开源库
开源库产生的根源在于开放源码社区,如Apache、Google和其他受欢迎的行业巨头公司和基金会贡献出庞大的代码和信息库。随着可获得代码信息的增加,互联网对它们的需求也会不断增加。
虽然Java已经被广泛应用在各种层面,学习Java的技术开发人员队伍也相当庞大,但是Java程序员也不用担心。新技术的兴起会让许多组织更加倾向于Java平台的选择,毕竟Java还是编程语言界的老大哥。
Java平台组首席架构师Mark Reinhold谈JAVA
在过去的二十年间,Java SE平台和JDK经历了很大的变化,其中每个演变步骤都变更很大、不规则并且在一定程度上来讲很难预测。历史上,每个特性释放版本都是由一个或多个重要特性驱动的,所以为了适应这些特性的研发进度,发布日程也会按需进行调整,有时候甚至不止调整一次。
这样做的好处就是能够以非常高的质量交付大型的新特性,在这个过程中会经过早期采用者的全面审查和测试。但是,它所带来的不足就是小型的API、语言和平台的变更无法单独发布,只能等到大特性就绪之后才能交付。
在过去的二十年中,这种发布节奏还是可以的,因为当时与Java竞争的只有几个平台,基本都是采用类似的发布节奏。但是,现在Java要与很多的平台竞争,这些平台的演化节奏更快。Java为了保持竞争力,必须要不断前进,而且要前进地更快。
当时Reinhold提出了将特性驱动的发布模式改为时间驱动的“列车”模式。在这种模式下,开发进程是一个持续的革新过程,它与实际的发布进程是松耦合的。不管特性大小,只有在接近完成的时候才合并进来。如果某个特性非常遗憾地错过了当前的这趟“列车”,那么这也不是世界末日,因为下一趟“列车”已经在等待中并且会按照时间表发车。
两年为间隔的“列车”模式在理论上很吸引人,但是事实证明在实践中行不通。Java 8为了解决关键的安全问题和完成Lambda项目多耗费了八个月的时间,但是这要比让Lambda项目再等两年更好一些。为了包含Jigsaw项目,Java 9最初的发布周期是两年半,虽然超出了半年,但是这要比让Jigsaw项目多等18个月更好,不过最终Java 9多耗费了一年的时间,也就是会在本月发布,这样从Java 8发布到现在经历了三年半的时间。
Reinhold认为,现在来看两年的发布周期太长了,交付特性的节奏应该更快一些。将某项特性推迟到下个版本发布,不应该是有重大影响的战略决策,而应该是影响不太大的战术性决策。因此,Reinhold认为六个月是一个合适的发布周期。它比以前更快,会减少等待下一趟“列车”的痛苦,同时也有足够的时间保证每次发布的质量。
提议
根据其他平台和各种操作系统版本的发布模式,Reinhold建议在Java 9之后,采用一种更严格基于时间模式,每六个月发布一个新特性释放版本,每季度发布一个更新释放版本,每三年发布一个长期支持的发布版本。
特性发布版本可以包含任何类型的特性,不仅包括新的以及增强的API,还包含语言和JVM的特性。特性只有在接近完成的时候,才会合并进来,所以当前要释放的版本始终都是特性已完成的状态。特性发布版本会在每年的三月和九月交付,从2018年的三月开始。
更新释放版本会被严格限制,只能解决安全问题、回归测试中的问题和bug。每个特性发布版本都会有两个更新版本,更新版本会按照季度发布,在每年的一月、四月、七月和十月交付。
从2018年的九月开始,特性发布版本同时也会是一个长期支持版本。对这些发布版本,至少会支持三年,甚至更长时间。
每半年交付一次的发布版本会比多年才交付一次的版本体量更小,更易于采用,同时为旧释放版本打补丁也会更容易。
开发人员更喜欢快节奏的创新,那么他们可以使用最新的特性发布版本或特性更新版本,这样就能尽快在生产环境使用新特性。他们可以通过Docker镜像或其他类型的容器包交付应用,容器中会同时包含应用所要使用的Java发布版本。
企业会更加关注稳定性,那么可以让多个大型的应用使用相同的Java版本,他们可以使用长期支持的发布版。像常规工作一样,他们可以每三年规划一次长期维护版本的升级。
为了明确特定版本的发布时间,特性发布版的版本号格式为$YEAR.$MONTH,因此明年三月份的发布版将会是18.3,九月份的长期维护版将会是18.9。
Reinhold认为,如果采用这种模式的话,将会影响到OpenJDK社区的贡献者。这项提议会最终影响每个依赖Java的开发者、用户和企业。但是,如果成功的话,将会在未来的很多年内保持Java的竞争力,同时能维持它的核心价值,也就是兼容性、可靠性以及稳健的特性演化。
人们选择使用Java的原因有很多个,我们先来看看最常见的几个:
· 简单性:Java为程序员和最红用户提供了最简单的体验,与其他编程语言相比这是Java最大的优势之一。Java消除了指针的意义,相对于C++的难度大大降低。
· 便携性:Java能够借助应用程序最任何软件和平台上运行。
· 便利性:Java具有堆栈提供系统的特性,可以帮助统计数据快速恢复。与其他web开发语言不同,Java拥有自动垃圾回收和内存分布功能。
· 分布式:Java平台具有良好的网络能力。这就意味着在Java上进行交互是非正式的,而编写网络应用程序的感觉就像是接收和发送文件。
· 安全性:Java的安全性是大众认可的。Java开发公司可以下载任何不受信任的文件,应用程序可以安全可靠的使用这些非安全性代码。
Java在大数据和互联网中的作用
在过去几年中,大数据和物联网在企业中只能算个流行词。其实这些概念存在的时间远比我第一次听到它的时间要长久,近些年技术的飞速发展,大数据和互联网技术也在不断成熟。大数据和互联网的关系相信大家都能说出一二:“物联网是感官,大数据是燃料,人工智能是实现智能连接未来世界的大脑。”
数以百万计的设备联网导致了大量数据的大量涌入。现有的大数据技术需要增强,以便对数据有效的进行存储、管理和价值提取。随着生产的数据持续增长,分析需求也会不断增加,而Java开发可能将是大数据和物联网的可预见的未来。
大量开源库
开源库产生的根源在于开放源码社区,如Apache、Google和其他受欢迎的行业巨头公司和基金会贡献出庞大的代码和信息库。随着可获得代码信息的增加,互联网对它们的需求也会不断增加。
虽然Java已经被广泛应用在各种层面,学习Java的技术开发人员队伍也相当庞大,但是Java程序员也不用担心。新技术的兴起会让许多组织更加倾向于Java平台的选择,毕竟Java还是编程语言界的老大哥。
Java平台组首席架构师Mark Reinhold谈JAVA
在过去的二十年间,Java SE平台和JDK经历了很大的变化,其中每个演变步骤都变更很大、不规则并且在一定程度上来讲很难预测。历史上,每个特性释放版本都是由一个或多个重要特性驱动的,所以为了适应这些特性的研发进度,发布日程也会按需进行调整,有时候甚至不止调整一次。
这样做的好处就是能够以非常高的质量交付大型的新特性,在这个过程中会经过早期采用者的全面审查和测试。但是,它所带来的不足就是小型的API、语言和平台的变更无法单独发布,只能等到大特性就绪之后才能交付。
在过去的二十年中,这种发布节奏还是可以的,因为当时与Java竞争的只有几个平台,基本都是采用类似的发布节奏。但是,现在Java要与很多的平台竞争,这些平台的演化节奏更快。Java为了保持竞争力,必须要不断前进,而且要前进地更快。
当时Reinhold提出了将特性驱动的发布模式改为时间驱动的“列车”模式。在这种模式下,开发进程是一个持续的革新过程,它与实际的发布进程是松耦合的。不管特性大小,只有在接近完成的时候才合并进来。如果某个特性非常遗憾地错过了当前的这趟“列车”,那么这也不是世界末日,因为下一趟“列车”已经在等待中并且会按照时间表发车。
两年为间隔的“列车”模式在理论上很吸引人,但是事实证明在实践中行不通。Java 8为了解决关键的安全问题和完成Lambda项目多耗费了八个月的时间,但是这要比让Lambda项目再等两年更好一些。为了包含Jigsaw项目,Java 9最初的发布周期是两年半,虽然超出了半年,但是这要比让Jigsaw项目多等18个月更好,不过最终Java 9多耗费了一年的时间,也就是会在本月发布,这样从Java 8发布到现在经历了三年半的时间。
Reinhold认为,现在来看两年的发布周期太长了,交付特性的节奏应该更快一些。将某项特性推迟到下个版本发布,不应该是有重大影响的战略决策,而应该是影响不太大的战术性决策。因此,Reinhold认为六个月是一个合适的发布周期。它比以前更快,会减少等待下一趟“列车”的痛苦,同时也有足够的时间保证每次发布的质量。
提议
根据其他平台和各种操作系统版本的发布模式,Reinhold建议在Java 9之后,采用一种更严格基于时间模式,每六个月发布一个新特性释放版本,每季度发布一个更新释放版本,每三年发布一个长期支持的发布版本。
特性发布版本可以包含任何类型的特性,不仅包括新的以及增强的API,还包含语言和JVM的特性。特性只有在接近完成的时候,才会合并进来,所以当前要释放的版本始终都是特性已完成的状态。特性发布版本会在每年的三月和九月交付,从2018年的三月开始。
更新释放版本会被严格限制,只能解决安全问题、回归测试中的问题和bug。每个特性发布版本都会有两个更新版本,更新版本会按照季度发布,在每年的一月、四月、七月和十月交付。
从2018年的九月开始,特性发布版本同时也会是一个长期支持版本。对这些发布版本,至少会支持三年,甚至更长时间。
每半年交付一次的发布版本会比多年才交付一次的版本体量更小,更易于采用,同时为旧释放版本打补丁也会更容易。
开发人员更喜欢快节奏的创新,那么他们可以使用最新的特性发布版本或特性更新版本,这样就能尽快在生产环境使用新特性。他们可以通过Docker镜像或其他类型的容器包交付应用,容器中会同时包含应用所要使用的Java发布版本。
企业会更加关注稳定性,那么可以让多个大型的应用使用相同的Java版本,他们可以使用长期支持的发布版。像常规工作一样,他们可以每三年规划一次长期维护版本的升级。
为了明确特定版本的发布时间,特性发布版的版本号格式为$YEAR.$MONTH,因此明年三月份的发布版将会是18.3,九月份的长期维护版将会是18.9。
Reinhold认为,如果采用这种模式的话,将会影响到OpenJDK社区的贡献者。这项提议会最终影响每个依赖Java的开发者、用户和企业。但是,如果成功的话,将会在未来的很多年内保持Java的竞争力,同时能维持它的核心价值,也就是兼容性、可靠性以及稳健的特性演化。