重拾JAVA:这种编程语言为什么不行了?

[系统运维] 时间:2025-11-05 11:19:02 来源:益强IT技术网 作者:IT科技 点击:28次

 本文转载自公众号“读芯术”(ID:AI_Discovery)

为了应对新工作,重拾种编笔者在过去两周一直在重新熟悉一位老朋友:JAVA。程语我以JAVA开启了我的重拾种编软件事业,与之共行了两年半左右的程语时间。但是重拾种编随着容器和微服务的出现,JAVA很快消失了。程语时至今日,重拾种编距我上次用Java正经写代码已有三年。程语笔者没想到它会再次出现,重拾种编尤其是程语出现在微服务领域。

这是重拾种编怎么回事?答案很简单:无处不在的微服务铺天盖地。

易于扩展 高可用性 更简单的程语代码库,不必担心并发和多线程 容器化带来的重拾种编便携性

所有这些都使人们质疑Java(更具体地说是JVM),更不用提Java最臭名昭著的程语Spring框架了。

有时,重拾种编人们沉浸在Kubernetes之类的技术中,感觉Java的时代已是历史,Java在容器和微服务生态系统中表现欠佳(软件可扩展性和高可用性的关键)。尽管被Python等语言(笔者现在的WordPress模板首选语言)的简单和优雅所动摇,但作为Java曾经的死忠粉,笔者认为Java仍在某些领域有毋庸置疑的优势。

例如,Java有强大的线程功能,笔者职业生涯的早期就将它们直接用于关键银行应用。虽然将编译语言与脚本语言的性能指标进行比较并不公平,但Java坚如磐石的性能确实无与伦比。

而对于水平扩展性和微服务体系结构,这种语言固有性能的作用微乎其微,因为人们可以直接产生更多容器来获得出色的性能。显然,这些脚本语言,再加上在容器范围内即时放大或缩小的能力,就能使Java打道回府了。笔者确信,Java已死,至少在微服务领域。

在新工作中,笔者进一步确信并痛苦地意识到这种语言有多令人厌恶、烦躁和费解(一部分在于Spring等过时的死板框架)。

Java与Spring的b2b供应网一派正经

首先讲讲臭名昭著的Spring框架。与五年前无异,Spring体积庞大且令人费解,充斥着无穷无尽的注释,开发人员每次要么得求助于教程或示例代码,要么只能研读Spring提供的冗长文档。

Spring本就采用了一种很死板的语言,用单行注释和看似简化的包装器加以掩盖,从而加剧了这个问题的严重性,这些包装器会带来一堆调用和类别例示,通常都派不上用场。

所有开发人员都同意这点:语言的可控性、指令和透明度对是高效开发软件的关键。简而言之,开发人员希望准确了解代码中发生了什么以及执行了哪些例程(至少是在较高层次上)。但Spring在此有着极大阻碍。

如果必须在类的顶部插入六个各自运行任务注释,它们在Spring环境中错综复杂地相互联系,那你的处境就复杂了。不仅Spring如此,以Lombok库为例。亿华云这是其首页上第一行描述:

“Lombok项目是一个Java库,它会自动插入您的编辑器和构建工具中,从而为您的Java增光添彩。无需再编写另一个getter或equals方法,一个带有注释的类将具有功能全面的生成器,自动执行日志记录变量等等。”

压缩Java代码的目标不过是照本宣科,不能真正发挥作用。

Java应该停止匹配脚本语言的简洁性。第一,这牺牲了Java代码的一致性:想象返回Java发现所有的getter和setter都消失了,取而代之的是单行注释@NoArgsConstructor。这哪还有一致性?

其次,它增加了本就费解的抽象数组。例如,Spring可以在后台设置自动装配(bean注入),这是可以理解的,但是Lombok在应用程序环境中位于何处,以及如何协调消息?如果每个类都有六个注释,那么这些注释还实例化了多少其他例程或类来完成这种简单的工作?

每个开发人员都不希望有额外的代码四处潜伏。然而这就是笔者三年后遇到的Java代码,没有任何改变。实际上,微小的变化也只会使情况变得更糟。Java仍然侧重于愚蠢的规则,这些规则规定了应使用的类名,所在的包,以及变量是私有的还是受保护的。但根本没人在乎这些。

相比之下,Python对缺少语言的访问说明符直接回复:“大家都是成年人了”。这仅仅一行的回复嘲讽意味十足又极具吸引力,它立刻引起了我的共鸣,我过去常常觉得荒谬且无用的概念在它的影响下合理了很多。

保持简单,程序员们

在软件行业,你经常能听到人们说“KISS”:保持简单(Keep it simple),傻子们(Stupid)。Java只有认真考虑这点才能生存。

如今,微服务模式在软件行业中几乎无处不在,甚至许多运行古早应用程序的组织也越来越多地替换其旧的整体,以简化设计并提高可扩展性。对于程序员而言,这意味着将其庞大的代码库或复杂的业务逻辑分解为更简单、简洁的功能——一种无需在代码中进行状态管理的范例,从而避免并发和多线程的问题。

归根结底,无论何种服务,都只处理某种格式(JSON或XML)的数据,然后将它们传递到消息总线(如Kafka)以进行进一步处理。即使是这样简单的设置中,Java和Spring还在照搬过时又死板的代码语法:Application Contexts、 bean injections,、autowiring、 POJO mappers、需要大量内存的 JVM、讨厌的 class loader。

所以,结论是什么?“保持简单,程序员们!”

(责任编辑:人工智能)

    大多数 Linux 发行版都会提供一个可以从 USB 启动的 live 环境,以便用户无需安装即可测试系统。我们可以用它来评测这个发行版或仅仅是当成一个一次性系统,并且很容易将这些文件复制到一个 U 盘上,在某些情况下,我们可能需要经常运行同一个或不同的 ISO 镜像。GRUB 2 可以配置成直接从启动菜单运行一个 live 环境,而不需要烧录这些 ISO 到硬盘或 USB 设备。获取和检查可启动的 ISO 镜像当镜像下载完后,我们应该通过 MD5 校验检查它的完整性。这会输出一大串数字与字母合成的序列。将这个序列与下载页提供的 MD5 校验码进行比较,两者应该完全相同。配置 GRUB 2在下面的例子中,一个 Kubuntu 15.04 live 环境将被配置到 Ubuntu 14.04 机器的 Grub 启动菜单项。这应该能在大多数新的以 Ubuntu 为基础的系统上运行。假如你是其它系统并且想实现一些其它的东西,你可以从这些文件了解更多细节,但这会要求你拥有一点 GRUB 使用经验。这个例子的文件 kubuntu-15.04-desktop-amd64.iso 放在位于 /dev/sda1 的 /home/maketecheasier/TempISOs/ 上。为了使 GRUB 2 能正确找到它,我们应该编辑/etc/grub.d40-custom分析上述代码下一行是指定回环设备,且必须给出正确的分区号码。复制代码代码如下:GRUB 的命名在这里稍微有点困惑,对于硬盘来说,它从 “0” 开始计数,第一块硬盘为 #0 ,第二块为 #1 ,第三块为 #2 ,依此类推。但是对于分区来说,它从 “1” 开始计数,第一个分区为 #1 ,第二个分区为 #2 ,依此类推。也许这里有一个很好的原因,但肯定不是明智的(明显用户体验很糟糕)..在 Linux 中第一块硬盘,第一个分区是 /dev/sda1 ,但在 GRUB2 中则是 hd0,1 。第二块硬盘,第三个分区则是 hd1,3, 依此类推.下一个重要的行是:复制代码代码如下:最后复制代码代码如下:启动 live 系统复制代码代码如下:当重启系统后,应该可以看见一个新的、并且允许我们启动刚刚配置的 ISO 镜像的 GRUB 条目:选择这个新条目就允许我们像从 DVD 或 U 盘中启动一个 live 环境一样。探究联想电脑0198错误的原因及解决方法(解读联想电脑启动出现0198错误的常见原因和有效解决方案)
    相关内容
    精彩推荐
    热门点击
    友情链接