准备内容素材的时候是痛苦的,因为要照顾到所有人,所以往往不知道该准备什么内容合适。之前一直跟大家聊得是Java如何入门、Java面试等一些问题,今天跟大家聊一聊Java开发中出现的那些新技术,刚入门的同学也可以看一看,提前灌个耳音 ~
作为一个开发人员,我们最大的挑战就是保持自己了解新的技术。技术变化很快,你大概每两年就会看到一个新版本的编程语言和框架,甚至更快(比如前端行业)。
就拿过去的2017年来说,AR、VR、区块链、人工智能等等已经扑面而来了。除了这些离我们较远的,说几个离我们最近的:JDK 9、 Spring 5、 Spring Security 5、 Spring Boot 2、ServiceMesh等。
过去的这一年对于一个Java开发来说可能是最忙碌的一年了,我们还在学习使用Java 8的Stream API的时候,Java 9的模块化已经来了,而当我们要开始学习Java 9的时候。今年三月份,Java 10已经正式发布,关于Java 10,本文先不表。JDK 9 有很多有趣的功能如Jigsaw、JShell、Stack-Walking API等,所以,仅仅是这些东西足够2018年的你好好学习一番了。
再拿Spring来说说,可能情况更加严重,毫不客气的说,很多人可能还不知道Spring 4有哪些特性,甚至项目中还在用Spring 3.1 ,更别提新出来的Spring 5、 Spring Security 5这些东西了。想想有多可怕,我们现在用的竟然是五六年前的技术。
前几天我在看搭建企业项目相关的教学视频,里面的内容竟然还是让开发者通过导入jar包的方式搭建SSH环境,看到这里,我真的有点担忧,尤其那些初级Java开发者,甚至是还没毕业的你。或者是很多工作了多年的你。新技术,请学起来!!!跟我一起!
下面是我列的一些你需要了解的一些技术(和Java相关部分),供你参考。
0、 Gradle
Java世界中主要有三大构建工具:Ant、Maven和Gradle。经过几年的发展,Ant几乎销声匿迹,还剩Maven和Gradle两种,maven是我目前工作中用的版本管理工具。
maven现在已经是行业标准,Gradle算是后起之秀,很多人对他的了解都是从android studio中得到的,Gradle抛弃了Maven的基于XML的繁琐配置。取而代之的是Gradle采用了领域特定语言Groovy的配置,大大简化了构建代码的行数。
正好也可以借着学习Gradle的机会深入学习一下Groovy。
1、 Python
最近我已经在开始学习Python了。最初想学习他的动机是想借助Python做一些爬虫、数据分析相关的事情。作为一种语法简单的高级语言,Python有很多优点。对于一个Java程序员来说,学习Python是很容易的。
在StackOverflow2017开发者调查中。所有最受欢迎的语言中,Python超越PHP位居第五,在你最希望使用哪种语言排行榜中,Python 夺冠,而去年仅仅第四。所以,如果你准备学习一门新的语言,Python绝对是个很好的选择。
2、 Java 8 和 Java 9
就像我说的,和绝大多数Java开发人员一样,仍然在学习Java 8。2018年仍然会继续学习并大量使用Java 8。
我也会花一些时间学习Java 9的新特性,比如Jigsaw, Reactive Streams, Process API, HTTP2 client, JShell等也在学习清单中。
3、 Spring 5
2017年我们见证了见证了Spring和Java生态系统的许多重大升级,Spring 5.0就是其中之一。
Spring 5 的新反应式编程模型、HTTP/2 支持,以及 Spring 通过 Kotlin 对函数式编程的全面支持这些都值得我们好好了解一下。
4、 Spring Security 5.0
Spring Security 5.0 提供了许多新功能,并支持 Spring Framework 5.0,总共有 400 多个增强功能和 bug 修复。在Spring Security 5.0.0之前,密码是明文保存,十分不安全,这一次的新版本则使用更安全的密码存储方式。
Spring Security 5.0.0的主要亮点在于它只需要最小化的JDK 8、反应式安全特性、OAuth 2.0(OIDC)和现代密码存储。
5、 Spring Boot 2
Spring Boot 2.0 基于 Spring 5 Framework ,提供了 异步非阻塞 IO 的响应式 Stream 、非堵塞的函数式 Reactive Web 框架 Spring WebFlux等特性。
很多使用过SpringBoot的人都知道,使用SpringBoot搭建Web应用真的是又快又好,相信Spring Boot 2会带来更多惊喜。
6、 Apache Spark 和 Kafka
另外一件2018年要深入学习的是大数据相关的知识。特别是Apache Spark 和 Kafka两个框架。
我不确定大家是否会有时间看其他大数据技术,这两个至少在当前还是比较火的。
7、 ServiceMesh
显然,这是个新东西,很新。或许在读这篇文章的你并没有听说过。那么恭喜你,此时此刻你已经在这个方面超过了大部分程序员。
ServiceMesh,他被业内誉为下一代微服务,现在整个领域都处于初级阶段。早学早受益。
8、 Serverless
无服务器运算(英语:Serverless computing),又被称为功能即服务(Function-as-a-Service,缩写为 FaaS),是云计算的一种模型。以平台即服务(PaaS)为基础,无服务器运算提供一个微型的架构,终端客户不需要部署、配置或管理服务器服务,代码运行所需要的服务器服务皆由云平台来提供。
这东西,听上去就很高大上。
9、Others
Docker 、MicroService、Kubernets、Spring Cloud、Redis....
作为一名程序员,更需要不断丰富自己的知识库。我们所知道的东西,就像一个白色的圆圈,圈外则是黑暗的未知的世界。当圆圈越大,所接触到的黑暗部分就越多。我们只有不停地学习,才能打破更多的黑暗,找到更多光明。