写点什么

为什么说 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:5212026
用户头像
刘燕 InfoQ高级技术编辑

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

关注

评论 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
回复
没有更多了
发现更多内容

RocketMQ 5.0 无状态实时性消费详解

Apache RocketMQ

阿里云 RocketMQ 消息队列

2025最新测评:亲测国内主流的十大电子签章软件

数字工具研究

电子签章软件 电子签章软件怎么选

CI/CD与模型监控平台集成MLOps系统实现的全面路径

申公豹

人工智能

扣子Coze智能体万字教程:从入门到精通,一文掌握AI工作流搭建

极客天地

基于 EventBridge API Destination 构建 SaaS 集成实践方案

Apache RocketMQ

阿里云 消息队列 EventBridge

事件总线 + 函数计算构建云上最佳事件驱动架构应用

Apache RocketMQ

云原生 函数计算 事件总线 架构应用

3.99万的人形机器人来了,宇树也开源了自己的核心技术

程序员晚枫

机器人 宇树科技

RocketMQ 在业务消息场景的优势详解

Apache RocketMQ

阿里云 RocketMQ 消息队列

阿里云 API 网关 x OKG:游戏连接治理的「最后一公里」

阿里巴巴云原生

RocketMQ 5.0 可观测能力升级:Metrics 指标分析

Apache RocketMQ

阿里云 RocketMQ 云原生 消息队列

Anime.js - 轻量级JavaScript动画库

qife

前端 动画

当海豚智能遇见百度智能云:AI重绘超声医疗普惠新图景

科技热闻

园林维护管理系统(源码+文档+讲解+演示)

深圳亥时科技

RocketMQ 集成生态再升级:轻松构建云上数据管道

Apache RocketMQ

阿里云 RocketMQ API 业务架构 EventBridge

ROS系统MoveIt玩转双臂机器人系列(一)--ROS机器人建模

芯动大师

大数据-53 Kafka 架构精讲:Producer、Broker、Consumer 全流程解析

武子康

Java 大数据 kafka 分布式 后端

火山引擎DataAgent:AI完成从“数据洞察”到“自主行动”质变

极客天地

MIAOYUN | 每周AI新鲜事儿(07.18-07.25)

MIAOYUN

云计算 AI AI+ 人工智能 aiinfra AI Infra

低精度算术提升机器人定位效率 - 亚马逊科学团队技术创新

qife

机器人技术 SLAM算法

工业互联网的下一站:卡奥斯的AI大模型解法

脑极体

AI

AI智能体时代,看华为云AI原生应用引擎2.0——Versatile如何脱颖而出,面向千行万业,打造最佳企业Agent平台

华为云开发者联盟

RocketMQ 监控告警:生产环境如何快速通过监控预警发现堆积、收发失败等问题?

Apache RocketMQ

阿里云 RocketMQ 云原生 消息堆积

消息收发弹性——生产集群如何解决大促场景消息收发的弹性&降本诉求

Apache RocketMQ

阿里云 RocketMQ 云原生

面向智能医疗的边缘计算与云计算融合架构的设计与实现

申公豹

人工智能

Lemon AI 打造全栈通用AI智能体

AGICamp

AI应用 agent +AI AI 智能体 AGICamp

WAIC 2025 | 北电数智发布新天·智能体平台,加速“更懂行业”的智能体落地

Lily

从互联网到云时代,Apache RocketMQ 是如何演进的?

Apache RocketMQ

阿里云 RocketMQ 消息队列

手机秒变PC主控台:ToDesk、AnyDesk、向日葵、网易UU手机远程控制对比

fine

远程

无监督通用异常检测方法SEAD解析

qife

机器学习 无监督学习

亚太移动通信业贡献9,500亿美元GDP

财见

[VLDB 2025]面向Flink集群巡检的交叉对比学习异常检测

阿里云大数据AI技术

人工智能 云计算 大数据 flink 异常检测

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