免费下载案例集|20+数字化领先企业人才培养实践经验 了解详情
写点什么

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

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

关注

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

APISIX-Datadog 插件发布,助力用户提高系统的可观测性

API7.ai 技术团队

云原生 可观测性 API网关 APISIX Datadog

混合云管理软件用哪个品牌好?咨询电话多少?

行云管家

Python代码阅读(第66篇):两个列表的包含关系

Felix

Python Code 列表 阅读代码 Python初学者

从双十一的物流大战,看全球通信网络的低延迟优化

融云 RongCloud

音视频 通信 低延迟 全球通信

读《区块链技术及应用第二版》华为区块链发展思路、双引擎战略及华为区块链特点和使用有感

孙叫兽

区块链 华为链 华为区块链服务

ONES Talk | 我们为什么选择最难走的软件之路

万事ONES

SaaS ONES

高维数据世界|基于高维稀疏矩阵的潜在变量模型研究

索信达控股

算法 变量模型 模型介绍 高维数据

英特尔宋继强:秉持三个坚持,穿越技术周期,构建未来技术生态

科技新消息

WICC 广州高峰对话:为开发者标注「航海地图」

融云 RongCloud

开发 游戏 社交 泛娱乐 出海

你有一份「写作跨年」邀请函请查收 | 28天写作计划

TGO鲲鹏会

写作 技术创作 28天写作 内容创作 热门活动

【最全攻略】玩转2021LIGHT开发者云大会

恒生LIGHT云社区

技术 开发 行业 行业大会

字节跳动亿级DAU客户端发布最佳实践

字节跳动终端技术

元气部落盲盒小程序开发芒趣盲盒app开发

风行无疆

react源码解析6.legacy模式和concurrent模式

buchila11

React React Hooks

新思科技BSIMM12报告显示开源、云、容器安全活动增长显著

InfoQ_434670063458

新思科技 软件安全 BSIMM

专家推荐五个免费的网络安全工具

喀拉峻

网络安全 安全 渗透测试 渗透

ONES Automation 流程自动化解决方案

万事ONES

自动化 SaaS

Linux一学就会之Vim编辑器的使用和Xmanager工具的使用。

学神来啦

vim Linux centos 运维 ext4

建立合格的跨职能团队,你需要知道这些!

禅道项目管理

团队 合作共赢

【IT运维小知识】虚拟化vCenter是什么意思?有啥优势?

行云管家

Java&Go三种HTTP客户端性能测试

FunTester

Java 性能测试 测试框架 Go 语言 FunTester

行业视野 | ONES CEO 王颖奇对话极客公园张鹏

万事ONES

SaaS SaaS平台

react源码解析5.jsx&核心api

buchila11

React React Hooks

Rust 元宇宙 9 —— 库和序列化

Miracle

rust 元宇宙

一页纸需求的应对方法 —— 五步法

CODING DevOps

业务价值 角色梳理 术语定义 主业务流程梳理 纲举目张

手把手带你写一个 Vue3 的自定义指令

CRMEB

社交泛娱出海新引擎,融云「六化」能力助开发者轻装上阵

融云 RongCloud

游戏出海 出海社交 出海

创新模式驱动生产力提升,融云社交场景化 SDK 探索

融云 RongCloud

直播 sdk 语聊房 场景化

看完这5个核心功能,你会明白低代码平台到底能解决什么问题!

J2PaaS低代码平台

低代码 低代码开发 低代码平台

数据产品经理实战-指标体系搭建

第519区

数据产品经理 数据产品 指标体系 指标管理

”微博评论“的高性能高可用计算架构设计

Steven

架构实战营

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