阿里、蚂蚁、晟腾、中科加禾精彩分享 AI 基础设施洞见,现购票可享受 9 折优惠 |AICon 了解详情
写点什么

为什么说 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/


公众号推荐:

2024 年 1 月,InfoQ 研究中心重磅发布《大语言模型综合能力测评报告 2024》,揭示了 10 个大模型在语义理解、文学创作、知识问答等领域的卓越表现。ChatGPT-4、文心一言等领先模型在编程、逻辑推理等方面展现出惊人的进步,预示着大模型将在 2024 年迎来更广泛的应用和创新。关注公众号「AI 前线」,回复「大模型报告」免费获取电子版研究报告。

AI 前线公众号
2020-01-30 11:5211660
用户头像
刘燕 InfoQ高级技术编辑

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

关注

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

第一个模块作业

achilles

阿里最新丰碑:国内第一本凤凰架构,全面构建可靠大型分布式系统

碌碌无为小码农

Java 架构 程序人生 编程语言 经验分享

【笔记】学《郭东白的架构课》:09|法则四:为什么要顺应技术的生命周期?

术子米德

架构师成长笔记

php中序列化与反序列化

喀拉峻

网络安全

【笔记】学《郭东白的架构课》:12|法则五:如何提升一个架构设计的外部适应性?

术子米德

架构师成长笔记

“字节”再次起跳!内部651页剖析HotSpot 源码手册,GitHub开源

碌碌无为小码农

Java 面试 程序人生 编程语言 经验分享

后悔没有再点遇到!字节技术官DDD(领域驱动设计)手册,拆解业务代码首选

碌碌无为小码农

Java 架构 程序人生 编程语言 经验分享

混沌工程之 ChaosToolkit K8S 使用之删除 POD 实验

zuozewei

k8s 混沌工程 1月月更

【笔记】学《郭东白的架构课》:13|法则六:如何鉴别文化环境是否有利于架构师的生存?

术子米德

架构师成长笔记

被字节跳动气炸了!

Jackpop

项目管理的十大领域

石云升

项目管理 项目经理 1月月更

【笔记】学《郭东白的架构课》:11|法则五:架构师为什么要关注技术体系的外部适应性?

术子米德

架构师成长笔记

GitHub上线一天星标99.9K:阿里内部高逼格SpringCloud实战手册

碌碌无为小码农

Java 架构 面试 程序人生 编程语言

参数校验Spring的@Valid注解用法详解

JavaEdge

1月月更

【笔记】学《郭东白的架构课》:06|法则二:拼多多是如何通过洞察用户人性而脱颖而出的?

术子米德

架构师成长笔记

『内存中的操作系统』如何高效, 灵活的虚拟化内存(1)

soolaugust

操作系统 内存

Redis:我是如何与客户端进行通信的

碌碌无为小码农

Java 面试 程序人生 编程语言 经验分享

24 Prometheus之微服务监控概述

穿过生命散发芬芳

Prometheus 1月月更

【笔记】学《郭东白的架构课》:07|法则三:架构师如何找到自己的商业模式?

术子米德

架构师成长笔记

【笔记】学《郭东白的架构课》:01|模块导学:是什么在影响架构活动的成败?

术子米德

架构师成长笔记

如何用 Serverless 让 SaaS 获得更灵活的租户隔离、更优的资源开销

碌碌无为小码农

Java 架构 面试 经验分享 编程语言、

(1-20/20) 用技术实现更快、更好的销售

mtfelix

300天创作 2022Y300P

【笔记】学《郭东白的架构课》:08|架构师如何在一定时间内最大化自己的增量价值?

术子米德

架构师成长笔记

【笔记】学《郭东白的架构课》:05|法则二:研发人员的人性需求是如何影响架构成败的?

术子米德

架构师成长笔记

【笔记】学《郭东白的架构课》:04|法则二:架构师为什么要学习马斯洛的需求理论?

术子米德

架构师成长笔记

【笔记】学《郭东白的架构课》:03|法则一:如何找到唯一正确的架构目标?

术子米德

架构师成长笔记

【笔记】学《郭东白的架构课》:02|法则一:为什么有些架构活动会没有正确的目标?

术子米德

架构师成长笔记

架构实战训练营- 模块8 -作业

温安适

「架构实战营」

ReactNative进阶(三十二):前端构建工具--Yeoman

No Silver Bullet

React Native 1月月更 Yeoman

表妹和我纠结,线上系统因为一个ThreadLocal直接内存飙升

碌碌无为小码农

Java 架构 程序人生 编程语言 经验分享

【笔记】学《郭东白的架构课》:10|架构设计中怎么判断和利用技术趋势?

术子米德

架构师成长笔记

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