一起来立Flag吧!超炫的数据图表分析 2020 年 Java 技术趋势

引言

2020 来了,第一批 00 后已经 20 岁了,95 后也到了晚婚的年龄,员外的头发也越来越少了,新的一年大家有立下了哪些 Flag ?小伙伴们别急着立 Flag,让员外帮你分析一下哪些技术正流行、哪些技术已过时后再立也不迟。时势造英雄,技术也是一样,新的技术层出不穷,要真正做到顺势而为却又不随波逐流(少学点保护头发)。

数据来自JetBrains Developer Ecosystem Survey 报告,文末附上链接。

Java 版本对比

Java 8 作为Sun公司被 Oracle 收购后的第一个 LTS 版本(Long-term support:长期支持),有着很多新特性(包括:lambda、方法引用、Stream API、接口增强等),近三年吸引了大量旧版本用户迁移到 Java 8,而 Java 11 作为第二个 Oracle 发布的 LTS 版本(现已加入付费套餐)也获得了不错的使用率。

员外瞎评:

如果小伙伴们还在 Java 8 以前的版本,Java 8 是个不错的选择,一步到位的话选 Java 11 就没错了,如果想避免付费坑的话建议使用 AdoptOpenJDK 或者其他第三方 JDK,需注意 Java 8 也将在 2021 年开始收费。

员外 Flag :20 年输出 5 篇以上的 Java (特性、版本)原创文章。

Web 服务器使用对比

Tomcat 一骑绝尘,商业化版本服务器市场份额惨不忍睹。

员外瞎评:

Tomcat 以其简单灵活的使用方式,多到发指的部署方式,以及有 Apache 亲爹罩着,几乎垄断了 Web 服务器市场份额,Jetty 在前有 Tomcat 后有商业化服务器的夹缝中获得近 20% 的市场份额着实不易(Jetty:我太难了),对技术感兴趣的小伙伴可以考虑学习 Jetty。

员外 Flag :会在公众号发起投票,如果有人看我就搞一个系列。。。

替代 Web 服务器技术

员外学过 Spark Java ,设计理念很不错的,奈何生不逢时,刚有发展势头就被 Spring Boot 压死了。

员外瞎评:

这个没啥可说的,要学就学 Netty 吧,NIO老牌技术了。

员外 Flag :无(头发不够用,不想学Netty (╯‵□′)╯︵┴─┴ )。

打包、运行 Web项目方式

即便有了 Spring Boot 的加持,Jar 包使用比率上升依然不明显,猜测其原因之一应该是 War 包也可以直接 java -jar *.war 来运行的原因,说实话,员外也不能理解为什么会有那么多 Jar 包发布方式,依赖 Jar 包也统计了?

员外瞎评:

这个没有什么可评论的,数据变化不明显,可以跟踪观察明年数据变化,有知道原因的朋友可以留言指点。

员外 Flag :至少一篇解析 Spring Boot 可执行 Jar 解析。

Web框架使用对比

Spring Boot 以其优雅的设计理念再次颠覆了 Java Web 开发,甚至侵入到了非 Web 项目(使用可执行 Jar),蚕食了包括自家 Spring MVC 在内的所有 Web 框架使用率,Spring 第一次颠覆了 EJB,这次颠覆了自己。

员外瞎评:

喜闻乐见的是 Struts 系终于把自己玩死了,原本使用率第一的 Web 框架,教科书式的走向了穷途末路。

Spring Boot 堪称开源界的典范,无论是易于上手,难于精通的学习曲线,还是优雅的代码结构、完善的文档、快速的问题反馈、完整的生态体系,Spring Boot 不可能不火,一句话,Spring 系必学。

员外 Flag :10 篇以上的 Spring Boot 干货,老少咸宜,欢迎关注,如果大家有兴趣我也可以对比一下 Struts 与 Spring,简单分析一下开源框架如何玩死自己。

构建工具的使用

Maven 稳坐老大哥的位置,Gradle 紧随其后,Ant 不复昔日的辉煌,SBT 依然是最难用的构建工具(SBTools)。

员外瞎评:

不使用构建工具的人越来越少(可能是一些老古董级别项目),另外值得注意的是连续三年 Gradle 使用率都在上升,有可能是未来的趋势,值得学习一下。

员外 Flag :一系列 Gradle 学习文章(不确定能写几篇),同时附带与 Maven 的对比心得。

编译器(IDE)的使用

JetBrains公司的报告,大部分都是 IDEA 使用者,所以这个图不一定能代表 Java 生态圈。

员外瞎评:

工欲善其事,必先利其器,一个好用的 IDE 能大幅提高开发效率,想当初员外从 eclipse 转到 STS 惊为天人,后来使用了 IDEA,真香!

员外 Flag :会推荐一下好用的插件,使用技巧等等,数量随心吧。

总结

如同日志(参考我的系列文章)一样,有了 Spring 的加持,Java 程序员很安逸,除了Web以外还有大数据、安卓、游戏开发也有《我的世界》、编译器有 JetBrains 全家桶。拥有所有语言中最完善的生态又十分稳定,新技术多却迭代速度慢(前端:你说谁呢,食屎啦你),实际上 Java 近三年几乎也没有昙花一现的技术。员外将技术分三类:

  1. 不学你就 out 了:Spring Boot、IDEA、Tomcat、Maven 以及 Java 8 的新特性
  2. 值得关注的技术:Java 9、10、11、12、13、14...新特性、Gradle、VS Code
  3. 觉得自己头发够用可以作一下学习的技术:Netty、Jetty

以上是员外的经验之谈,正所谓吾生也有涯,而知也无涯,在学习新技术时应做到有的放矢,希望能够帮助朋友们在新的一年提供一些学习方向,让我们一起立下 Flag: 共同学习(暗示关注),争取在呵护头发的同时, 20 年技术突飞猛进。

注意了:文章中有两个彩蛋等你发现。

如果觉得写的不错,求关注、求点赞、求转发,如果有问题或者文中有错误,欢迎留言讨论。

扫码关注公众号,第一时间获得更新

数据来源:

https://www.jetbrains.com/research/devecosystem-2017/java/

https://www.jetbrains.com/research/devecosystem-2018/java/

https://www.jetbrains.com/lp/devecosystem-2019/java/

原文地址:https://www.cnblogs.com/xuningfans/p/12173277.html

时间: 2024-07-30 16:40:36

一起来立Flag吧!超炫的数据图表分析 2020 年 Java 技术趋势的相关文章

可删除超炫&多种特效的Card视图(改造自cardsui-for-android开源项目),提供DEMO下载

       这里贴几个效果图,我做了一个gif的动态图,但是不知道为什么上传后图片不动,所以只能放在相册里. 如果大家想看动态的图片演示请点击后面的链接gif动态演示图片 实例Demo下载地址在本文最后 简单介绍 这个Demo主要是使用了cardsui-for-android开源项目,并且做了一些优化和改进: 1.自定义card视图 2.添加长按事件,避免误操作 3.长按后可以删除card,并播放选中动画 4.删除后浮现一个悬浮button 5.点击悬浮button可以恢复之前删除的card视

几行css3代码实现超炫加载动画

之前为大家分享了css3实现的加载动画.今天为大家带来一款只需几行代码就可以实现超炫的动画加载特效.我们一起看下效果图: 在线预览   源码下载 实现代码: 极简的html代码: <div> <i></i> </div> css3代码: body { background: black; display: -webkit-box; display: -webkit-flex; display: -ms-flexbox; display: flex; heig

超炫的粒子效果!代码,就应该这么写!

最近瞎逛的时候发现了一个超炫的粒子进度效果,有多炫呢?请擦亮眼镜! 粗略一看真的被惊艳到了,而且很实用啊有木有!这是 Jack Rugile 写的一个小效果,源码当然是有的.聪慧如你,肯定觉得这个东西so easy 要看啥源码,给我3分钟我就写出来了吧.所以你的思路可能是: 1)进度条的实现没什么好说的,简单的一个 fillRect(0,0,long,20),long和20是分别进度条的长宽.然后每帧动画调用前将画布清除clearRect(0,0,canvas.width,canvas.heig

ScrollReveal.js – 帮助你实现超炫的元素运动效果

ScrollReveal.js – 帮助你实现超炫的元素运动效果 ScrollReveal.js 用于创建和管理元素进入可视区域时的动画效果,帮助你的网站增加吸引力.只需要给元素增加 data-scrollreveal 属性,当元素进入可视区域的时候会自动被触发设置好的动画.

8个超炫酷仿HTML5动画源码

1.jQuery万年历插件 带农历老皇历功能 这是一款基于jQuery的日历插件,这款日历插件和之前分享的日历控件有很大差异,它是一本万年历,包含了农历已经老皇历的功能,是一个挑好日子的工具.同时日历还可以查看本年度的放假安排,功能非常强大.有兴趣的朋友可以下载学习. 在线演示 源码下载 2.CSS3发光进度条动画 超炫酷的样式 这次我们要来分享一款非常炫酷的CSS3进度条动画,其样式风格类似于星球大战里面的那些激光剑效果.页面初始化时,可以设定进度条的值,但是我们也可以利用其配套的借口来动态改

一款由jquery实现的超炫的页面加载特效

今天为大家带来一款由jquery实现的超炫的页面加载特效.连续的几个页面分开特效.最后由三维的线条由远至近消失,然后由近至远出现.效果超级梦炫.一起看下效果图: 在线预览   源码下载 实现的代码. html代码: <svg xmlns="http://www.w3.org/2000/svg" viewbox="0 0 1200 600"> <line id="uno" x1="600" y1="0

你见过吗?9款超炫的复选框(Checkbox)效果

复选框(Checkbox)在各个浏览器中的效果不一致,因此很多 Web 开发人员会自己重新设计一套界面和使用体验都更佳的复选框功能.下面就给大家分享9款超炫的复选框(Checkbox)效果,纯 CSS3 实现,未使用任何图片. 温馨提示:为保证最佳的效果,请在 IE10+.Chrome.Firefox 和 Safari 等现代浏览器中浏览. 前面三款效果都是灵感来自移动应用程序的滑动选择框效果,在选择和未选择状态之间通过滑动来切换效果,非常的动感.效果的实现方面是借用了一个 DIV 标签和一个

CSS3实现的超酷超炫的立体开关效果

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-

patchca整合Spring MVC生成超炫的验证码

官方的色调单一,随机色也不随机,黑不拉几的,很难看. 为此做了扩展实现,并整合了spring mvc,生成的验证码漂亮多了. 官网: http://code.google.com/p/patchca/ 官方效果: 下面是我整合到spring并修扩展后的效果: package com.lavasoft.ntv.web; import org.patchca.color.ColorFactory; import org.patchca.filter.predefined.*; import org.