写点什么

为什么说 Java 仍将是未来的主导语言

  • 2020-01-30
  • 本文字数:3057 字

    阅读完需:约 10 分钟

为什么说Java仍将是未来的主导语言

Java 是一门通用型编程语言,由 Sun 微系统公司(后被甲骨文收购)于 1995 年推出。尽管 Java 已经 25 岁了,但仍然“宝刀未老”。


在 Stack Overflow 2019 年流行编程语言调查报告中,Java 位居第 5 位,有 41%的受调开发者认为 Java 仍然是一门受欢迎的编程语言。


使用 Java 的公司

stackshare.io 的数据显示,大概有 9028 家公司在使用 Java,其中包括:


  • 谷歌;

  • Uber;

  • Airbnb;

  • 亚马逊;

  • Pinterest;

  • Slack;

  • Instagram;

  • Netflix;

  • Spotify。

为何 Java 如此流行?


这得益于 Java 的关键特性:


  • 简单性:Java 为开发者和最终用户提供了简单易用的用户体验。与其他面向对象编程语言相比,Java 的设计和生态库具有巨大的优势。

  • 可移植性:Java 可以随时随地运行在任意的硬件上,有很多软硬件都在使用 Java。

  • 资源分配:堆栈分配、垃圾回收和自动内存管理,这些特性让 Java 与其他编程语言区别开来。

  • 分布式:Java 在网络上极具优势,通常可以自由地发送和接收文件。

  • 安全性:Java 的安全编程模型提供了很高的安全性。

Java 会继续流行下去吗?

相比于 ASP.NET、PHP、Python 等编程语言,使用 Java 开发的应用程序更多,从移动应用到 Web 应用,再到运行在可穿戴设备上的应用。

Java 在大数据领域的应用

与 Python 一样,Java 也在大数据领域占据主导地位。各种用于处理大规模数据的框架都是用 Java 开发的。

Apache Hadoop

Hadoop 是一个使用 Java 开发的框架,用于在分布式环境中处理大规模数据集。Hadoop 采用了主副架构模式,其中主节点负责控制整个分布式计算栈。Hadoop 在需要处理和分析大规模数据的公司当中很流行。


使用 Hadoop 的公司包括:IBM、亚马逊、英特尔等。

Apache Spark

Spark 是另一个主要使用 Java 开发的大数据处理框架。Spark 是一个集群计算框架,可以运行在数千台机器(分布式集群)上。Spark 被用在大型的 ETL、预测分析和报表应用程序中。


使用 Spark 的公司包括:Uber、Slack、Hubspot、Shopify 等。

Apache Mahout

Mahout 是一个使用 Java 开发的机器学习库和大数据工具,用于执行机器学习操作,比如分类、聚类和推荐。


使用 Mahout 的公司包括:Adobe、Facebook、LinkedIn、Foursquare、Twitter、雅虎等等。

Java JFreechart

JFreechart 是一个流行的开源大数据工具,用于可视化数据,可以用它制作各种图表,比如饼图、柱状图、线图、散点图、盒状图、直方图等等。

Deeplearning4j

Deeplearning4j 是一个深度学习 Java 库,用于构建各种类型的神经网络。Deeplearning4j 可以与 Spark 集成,运行在 GPU 上。


使用 Deeplearning4j 的公司包括:JPMorgan Chase、Wells Fargo、Interactive Brokers 等等。

Apache Storm

Storm 是一个开源的分布式实时计算框架,用于处理实时数据流。一个 Storm 节点可以在秒级处理数百万个作业。


Storm 在真实世界中的案例:


  • Twitter:Storm 为 Twitter 的很多系统提供了支持,例如实时分析、搜索、收益优化等。

  • Groupon:Storm 为 Groupon 的实时集成系统提供支持,在低延迟和高吞吐的情况下实现数据的分析、清理、规范化和处理大量不同的数据点。

  • Weather:weather.com 的 Weather Channel 使用 Storm 来收集和持久化天气数据。

Java 在物联网(IOT)领域的应用



甲骨文公司表示,灵活性和流行度是 IOT 程序员选择 Java 的主要原因。


Java 提供了大量的 API 库,可以很容易被应用到嵌入式应用程序中,所以 Java 适合用来进行 IOT 编程。相比其他编程语言,比如 C 语言,Java 在切换平台时更加顺畅,不容易出错。从 Java 被用在 PDA 设备和早期的手机上,它就已经成为嵌入式设备的一部分。Java 在可穿戴设备、电视、移动设备和其他电子设备上应用,这让它成为 IOT 编程的不二之选。

Android 应用程序

Java 借助 Android 应用程序组件统治了移动应用市场,通过谷歌应用商店安装的移动应用超过了 73%。超过 45 万个移动应用是用 Java 开发的,包括 YouTube、Tiktok 等等。


Java 在金融服务领域的应用

聊天机器人

因为可移植性、可维护性、调试、可视化等诸多方面的因素,Java 成了开发聊天机器人最好的工具。


IBM Watson Conversation Service、api.ai、pandorabots 都使用了 Java。

欺诈检测和管理

银行和金融公司使用 AI 工具进行金融欺诈和信用卡欺诈检测。Java 被用来开发这些 AI 工具,而 AI 工具为欺诈检测和风险管理带来了可不预知的见解、模式和预测模型。在开发 AI 工具时,Java 的安全性提供了额外的好处,因为它可以帮助 AI 系统更好地做出判断。


一些主要的银行和金融机构在欺诈检测系统中使用了 Spark。

交易系统

根据甲骨文网站对 Java 的描述,Java 为快速开发、测试和部署提供了一个平台,是开发电子交易系统的一个很好的选择。超过 80%的电子交易系统是用 Java 开发的,包括大部分 FIX 引擎。


Java 虚拟机提供的动态运行时编译优化在很多情况下比编译型语言(如 C++)具有更好的性能。官方 JVM 和 JRockit Real Time(JRRT)虚拟机提供了很低的延迟,让交易系统运行得更顺畅。


Enlyft 网站的数据显示,有 500 多家公司在使用 JRRT,其中 7%用在金融服务(比如交易系统)领域。

移动钱包

基于 AI 和 Java 算法开发的移动钱包,可以帮助用户在花钱时做出更智能的决策。

Java 在 Web 应用程序中的应用

w3tech 网站的数据显示,3.7%的网站使用 Java 作为服务器端编程语言。



使用 Java 开发的主要网站:


  • Aliexpress.com

  • Tianya.cn

  • Linkedin.com

  • Booking.com

  • Caijing.com.cn

  • China.com.cn

  • Amazonaws.com

  • Rednet.cn

  • Onlinesbi.com

  • Salesforce.com


用于 Web 开发的流行框架:


  • Spring MVC:最古老但也是最好的 Web 开发框架。它灵活多变,提供了很高的安全性。它的代码干净简洁,有一个强大的社区在提供支持。

  • Google Web Toolkit:完善的文档和支持,易学易用,可用于开发高度响应的应用程序。

  • JavaServer Faces:由甲骨文提供支持,提供了完善的文档、丰富的开发库。

  • Hibernate:高质量、可修改、可配置、非常方便、速度快,提供了多种数据库驱动,具有非常好的可伸缩性。

  • Struts:是 Web 应用程序的基础,减少了开发和测试时间,简化了测试工作。

  • Selenium:很多公司使用 Selenium 进行测试自动化和质量控制。一些主要的公司和机构(如 MIT、Hubspot、Intuit 等)在使用 Selenium。

科学应用和高端技术

Nasa World Wind

World Wind 是 Nasa 使用 Java 开发的一款工具,可以从卫星角度放大世界的任何一个地方。


World Wind 利用了 Landsat 卫星图像和航天飞机雷达侦测到的地形数据,用户可以以 3D 的视觉体验“游览”地球。

Sun SPOT

Sun SPOT 完全使用 Java 开发,是一个小型、无线、由电池提供动力的试验性平台,用于开发原先需要使用特定嵌入式系统的项目。

JPC(模拟器)

JPC 是一个完全使用 Java 开发的 x86 模拟器,可以运行在任何支持 Java 虚拟机的平台上。它让用户可以更好地控制软件的运行环境,不管他们使用了怎样的硬件或操作系统。JPC 的多层安全性为运行非安全软件提供了最安全的解决方案,是电脑病毒归档、保护机器免受恶意软件攻击或运行非稳定软件的理想选择。

嵌入式软件系统

据甲骨文网站透露,100%的蓝光播放器和 1 亿 2 千 5 百万台电视机设备使用了嵌入式 Java。

Java 在其他方面的应用

Java 还被广泛应用在其他方面。很多基于云的应用程序提供了 PaaS 服务,比如 Heroku、Google App Engine。Java(AWT、Swing 和 JavaFX)也被广泛应用于开发桌面 GUI 应用程序。Java 是企业软件(包括网络应用程序和 Web 服务)的主要开发语言,甲骨文宣称 Java 正运行在 97%的企业计算机上。


延伸阅读:


https://www.xamnation.com/why-java-will-remain-a-dominant-language-of-the-future/


2020-01-30 11:5211848
用户头像
刘燕 InfoQ高级技术编辑

发布了 1112 篇内容, 共 548.4 次阅读, 收获喜欢 1978 次。

关注

评论 5 条评论

发布
用户头像
作为.net c#开发来说我会从另一个角度看,java能做的c#几乎都能做(大数据好像木有),看刚才的排行java 41% c#31% 其它各大排行TIOBE PYPL都类似,说明.net平台本身足够优秀。再看国内java与c#的生态 10个java开发:1个.net开发,其中很大原因是国内对.net误解,所以c#潜力巨大。新人学java或其它平台转java机会很渺茫,不信问问你身边java应聘时的岗位竞争有多大
2020-02-01 20:06
回复
用户头像
除了生态一无是处
2020-01-31 13:52
回复
以下内容引用自Oracle官网对于java的介绍:
从笔记本电脑到数据中心,从游戏控制台到科学超级计算机,从手机到互联网,Java 无处不在!
97% 的企业桌面运行 Java

美国有 89% 的桌面(或计算机)运行 Java
全球有 900 万 Java 开发人员
排名第一的部署平台
有 30 亿部移动电话运行 Java(android)
100% 的蓝光盘播放器附带了 Java
有 50 亿张 Java 卡在使用
1.25 亿台 TV 设备运行 Java
前 5 个原始设备制造商均提供了 Java ME
以下内容引用自维基百科:
Java编程语言是个简单、面向对象、分布式、解释性、健壮、安全、系统无关、可移植、高性能、多线程和动态(var)的语言。
so?
展开
2020-02-01 17:49
回复
用户头像
25岁,正值青春壮年啊
2020-01-31 12:18
回复
用户头像
asp.net啥时候 变成一门语言了
2020-01-30 21:11
回复
没有更多了
发现更多内容

维权思考

成周

BATJ关于Redis的高频面试真题

爱好编程进阶

Java 程序员 后端开发

元宇宙核心技术--脑机接口

CECBC

4年JAVA外包终上岸,我只能说避雷这些公司

爱好编程进阶

Java 程序员 后端开发

2021年4月23号,成功斩获阿里(Java岗

爱好编程进阶

Java 程序员 后端开发

What?构造的查询语句会导致堆栈溢出

华为云开发者联盟

neo4j 图数据库 堆栈溢出 查询语句 查询语言

动手实操丨RC522射频卡模块与IC卡完成充值消费查询的技术实现思路

华为云开发者联盟

stm32 RC522射频卡模块 IC卡 RC522

15 个优秀开源的 Spring Boot 学习项目,一网打尽!

爱好编程进阶

Java 程序员 后端开发

终于有人把tomcat讲清楚了!阿里大牛推荐的tomcat架构解析文档

Java架构追梦

Java 后端开发 JVM’

7Z命令行

爱好编程进阶

Java 程序员 后端开发

BAT华为等一线大厂Java工程师必读书单

爱好编程进阶

Java 程序员 后端开发

云图说 | 华为云医疗智能体EIHealth,AI赋能基因组研究

华为云开发者联盟

华为云 云图说 EIHealth 医疗智能体 基因组

区块链 重塑不良资产互信机制

CECBC

微服务实战文档分享,阿里内部的Spring cloud微服务精髓都在里面

Java架构追梦

Java 微服务 阿里

让 Rust 的 CI 加速 2~3倍速度

非凸科技

rust 构建 cl cithub 缓存空间

(JavaSE)数据类型变量与运算符

爱好编程进阶

Java 程序员 后端开发

耗时三年终于整理出了SSM+微服务+Nginx+Redis+MySQL的PDF了!

Java架构追梦

Java 后端开发

2021全网最全Activiti7教程02(Activiti7入门使用-欢迎收藏)

爱好编程进阶

Java 程序员 后端开发

[Day36]-[二叉树]-在每个树行中找最大值

方勇(gopher)

LeetCode 二叉树 数据结构算法

OpenHarmony 3.1 Beta版本关键特性解析——分布式DeviceProfile

OpenHarmony开发者

OpenHarmony OpenHarmony 3.1 Release DeviceProfile

架构师成长路线

AI架构师汤师爷

软件架构 架构师 成长路线

不愧是字节跳动技术官,算法精髓全写这本666页笔记里了

Java架构追梦

Java 程序员 数据结构与算法、

13-注解增删改查

爱好编程进阶

Java 程序员 后端开发

2021-11-9【数据结构平时实验】

爱好编程进阶

Java 程序员 后端开发

2年工作经验的Java程序员面试经历

爱好编程进阶

程序员 后端开发

快来跟20年京东T9架构师学习进阶微服务+Docker+Dubbo+SpringBoot

Java架构追梦

spring java面试 后端开发

内存不超过5M,datop 在识别冷热内存及跨 numa 访存有多硬核?| 龙蜥技术

OpenAnolis小助手

cpu 内存 datop 轻量级 muma

显卡只是为游戏而生吗?GPU服务器了解一下

Finovy Cloud

GPU服务器 GPU算力

Stack 顿悟三部曲(1):从CPU的视角说起

蓬蒿

cpu 堆栈 计算机原理 stack

《数字经济全景白皮书》Z世代用户洞察篇 完整版 发布

易观分析

Z世代

Apache ShardingSphere 企业行|走进汽车之家

SphereEx

数据库 企业 ShardingSphere SphereEx apache 社区

为什么说Java仍将是未来的主导语言_语言 & 开发_Rishav Kaundal_InfoQ精选文章