标签 C 下的文章

Java屹立30年,Go的“少年壮志”如何续写辉煌?——来自Java之父的“长寿秘诀”

本文永久链接 – https://tonybai.com/2025/05/17/java-at-30

大家好,我是Tony Bai。我的极客时间《Go进阶课》专栏已经上线,欢迎大家点击链接订阅学习,我们一起在Go语言的道路上共同精进!

Go语言自开源以来,已走过十多个年头。从最初备受瞩目的“Google语言”,到如今在云原生、微服务领域独当一面,Go 凭借其简洁、高效与强大的并发能力,赢得了全球开发者的青睐,正从一个朝气蓬勃的少年”迈向更加成熟稳健的“壮年”。

然而,“成长的烦恼”也随之而来:生态如何持续繁荣?语言如何在保持核心优势与满足新兴需求之间取得平衡?如何应对一波又一波的技术浪潮冲击?

恰逢 Java 语言诞生 30 周年,The New Stack 对 Java 之父 James Gosling 进行了一次深度访谈。我刚接触 Java 时,它才发布 1.5 版本(Tiger),一晃近 20 年,Java 依然是全球最重要的语言之一。这位编程语言界的“老大哥”和它的创造者,其“长寿秘诀”无疑能为“风华正茂”的 Go 语言带来诸多启示。

Gosling 在访谈中分享了 Java 长盛不衰的关键,我提炼了几点,希望能为Go的未来之路提供一些借鉴与思考。

秘诀一:【解决真实问题,而非追逐时髦】—— Go 的初心与未来挑战

  • Java 的经验: James Gosling 强调:“Java 从不追求时髦,始终专注于有效解决问题,帮助工程师完成工作。” 这份对实用主义的坚守,是 Java 能够穿越多个技术周期的基石。
  • Go 的启示与思考: Go 语言的诞生,正是为了解决当时 C++ 开发的复杂性、Python 等脚本语言的性能瓶颈以及多核时代并发编程的困境。它以大道至简的哲学,直击痛点,迅速在云原生、分布式系统等领域找到了自己的核心价值。

如今,Go 已走过开源的第一个十年,生态日渐成熟。面对 AI 浪潮、不断演进的硬件架构以及更多元化的应用场景,Go 是否还能保持这份“解决真实问题”的初心?未来,Go 需要识别并解决哪些新的、关键的“真实问题”,以巩固和拓展自身的生态位?这是每一个 Gopher 和 Go 社区贡献者都需要思考的。

秘诀二:【尊重用户,死磕向后兼容与可靠性】—— Go 的生命线如何延续?

  • Java 的经验: “尊重用户”、“保持向后兼容”、“优先考虑可靠性 (必须每次都TM的能用!)”——Gosling 的这些话掷地有声,道出了 Java 赢得企业信任的关键。
  • Go 的启示与思考: Go 语言著名的“Go 1 兼容性承诺”为其赢得了极佳的口碑,让开发者能够放心地升级版本。然而,随着 Go Modules、泛型等重要特性的引入,社区中也出现了一些关于“必要妥协”与“更大收益”的讨论。

当 Go 生态越来越庞大,用户场景越来越复杂时,如何在不牺牲核心稳定性的前提下,引入必要的改进和演化?如何在社区对某些“破坏性但可能带来更大价值”的变革呼声与“向后兼容”的承诺之间找到最佳平衡点?这将持续考验 Go 核心团队的智慧和社区的共识。

秘诀三:【谨慎创新,不轻易破坏核心价值】—— Go 的“简洁”能否持久?

  • Java 的经验: 谈及 Lambda、泛型等重要特性时,Gosling 表示:“我从不想加入一个不‘对’的东西。”他坦言确定最佳实现方式的艰难(“最初的90%很容易想出来,但最后10%超级难”)。这种对语言核心价值的审慎态度,避免了 Java 过早地陷入复杂性的泥潭。
  • Go 的启示与思考: Go 在引入泛型时,同样经历了长达数年的社区讨论和极其审慎的设计过程,最终才在 Go 1.18 中落地。这种“慢”在某种程度上保证了新特性与 Go 整体设计哲学的融合。

未来,Go 必然会面临更多引入新特性的需求。如何在满足发展需要与保持语言核心的“简洁性”和“工程效率”之间取得平衡,避免语言的“膨胀”和“复杂化”,将是 Go 能否保持其独特魅力的关键。我们是否应该继续推崇“少即是多”?哪些领域的创新是必要的,哪些又是需要警惕的?

秘诀四:【社区是活水之源】—— Go 的生态如何更上一层楼?

  • Java 的经验: 即便在 Oracle 的管理下(Gosling 对 Oracle 的评价是“比预想的好,但期望本来就很低”),他也承认社区在 Java 持续发展和创新中扮演了至关重要的角色。
  • Go 的启示与思考: Go 拥有一个全球化、充满活力且贡献卓著的社区。从无数优秀的开源项目到各种技术峰会、meetup,社区的力量是 Go 快速成长的重要驱动力。

进入成熟期后,如何进一步赋能社区,形成更强大的合力?例如,在语言特性方面(如更完善的错误处理、更丰富的原生数据结构支持等,虽然泛型已带来一些改善),如何更好地组织和激励社区进行共建?如何让更多的企业和个人开发者参与到 Go 的核心贡献和生态治理中?这将是 Go 能否持续保持创新活力的关键。

秘诀五:【保持清醒的自我定位,警惕技术炒作】—— Go 在浪潮中的定力

  • Java 的经验: Gosling 对当前 AI 热潮的一些犀利点评(例如,称其为“自带一桶有毒废料的营销术语”,认为“大部分 AI 投资将化为乌有”,以及 AI 编码工具在复杂项目中“几乎总是会崩溃”)展现了一种宝贵的清醒和批判精神。他认为 AI 更多是“极其复杂的锤子和螺丝刀”,是人类使用的工具,而非取代人类的自主系统。
  • Go 的启示与思考: 面对一波又一波的新兴技术浪潮(从区块链到元宇宙,再到如今的生成式 AI),Go 语言需要有清晰的自我认知和战略定力。它在技术栈中的核心价值是什么?最适合解决哪些领域的问题?

Go 在并发处理、网络编程、系统构建方面的优势,使其在云原生、微服务、分布式系统以及 AI 应用的后端基础设施等领域大放异彩。未来,Go 如何在这些领域继续深耕,同时审慎地探索与新兴技术的结合点,而不是被短期热点裹挟,盲目扩张,这将考验 Go 社区的集体智慧。

小结:知易行难,未来可期

James Gosling 的访谈,不仅仅是对 Java 30 年的回顾,更像是一堂浓缩的技术发展史和语言设计哲学课。虽然很多“名言警句”(比如他对某些公司文化的吐槽,或者对过时工具的调侃)非常抓人眼球,但其背后对技术本质的坚守、对用户价值的尊重、以及对行业趋势的冷静洞察,或许才是 Java 能够穿越周期、屹立 30 年的深层原因。

Go 语言,这位“刚刚十多岁的少年”,正处在发展的黄金时期,也面临着成长的关键抉择。借鉴 Java 这位“老大哥”的宝贵经验,或许能帮助 Go 走得更稳、更远。

想更全面了解 James Gosling 的观点和那些有趣的编程往事吗?推荐阅读原文:
Java at 30: The Genius Behind the Code That Changed Tech


聊一聊,聚焦 Go 的未来:

  • 你认为当前 Go 语言发展面临的最大挑战是什么(技术层面或生态层面)?
  • 借鉴 Java 的经验,你觉得 Go 社区或官方在哪些方面可以做得更好,以确保其长期健康发展?
  • 对于 Go 语言的核心价值(如简洁、并发、工程效率),你认为在未来演进中最需要坚守的是什么?

欢迎大家围绕 Go 的未来发展,在评论区分享你的深度思考!如果你觉得这篇文章对你有所启发,也请转发给你身边的 Gopher 朋友们,让我们一起为 Go 的未来出谋划策。

想与我进行更深入的 Go 语言与 AI 技术交流吗? 欢迎加入我的“Go & AI 精进营”知识星球

img{512x368}

我们星球见!


商务合作方式:撰稿、出书、培训、在线课程、合伙创业、咨询、广告合作。如有需求,请扫描下方公众号二维码,与我私信联系。

百万行依赖的“恐惧”:一位Rust开发者的深度反思与Go的启示

本文永久链接 – https://tonybai.com/2025/05/10/rust-dependencies-scare-me

大家好,我是Tony Bai。

在现代软件开发中,高效的包管理系统和繁荣的开源生态极大地加速了我们的开发进程。Rust语言的Cargo及其crates.io生态便是其中的佼佼者,为开发者带来了前所未有的便捷。然而,这种便捷性是否也伴随着一些潜在的“代价”?

近期,一位名叫Vincent的国外Rust开发者在其博客文章《Rust Dependencies scare Me》中,就真诚地抒发了他对Rust依赖管理的深切忧虑。这篇博文在Hacker News等社区引发了热烈讨论,其指出的问题——从依赖的维护性到惊人的代码体积——或许也值得我们每一位使用现代包管理系统的开发者深思。

今天,我们就来一起解读Vincent的这篇文章,看看他遇到了哪些具体问题,并结合社区的智慧与我们的经验,探讨这些现象背后的启示。

Cargo的魅力:作者眼中的“美好一面”

在这位开发者看来,Cargo无疑是Rust生态的巨大优势。他强调,Cargo极大地提升了生产力,开发者无需像使用CMake(多用于C++项目)那样手动管理和链接文件。这使得在不同架构和操作系统(如他的M1 MacBook和Debian桌面)之间切换变得异常顺畅。

他坦言,在大部分情况下,Cargo让他几乎可以不必过多思考包管理本身,从而能更专注于核心代码的编写。这种“无感”的便捷体验,与上世纪80年代开发者需要为节省软盘空间而精打细算地“手动挑选和集成库代码”形成了鲜明对比,无疑是现代包管理系统追求的目标,也是Rust吸引开发者的重要原因之一。

当便捷遭遇“意外”:dotenv引发的警惕

然而,文章作者也指出,正是这种“不用思考”的便捷,可能让人变得“草率”。

他在一个生产项目中使用了许多Rust开发者都用过的dotenv库(用于加载.env文件)。项目平稳运行数周后,他偶然发现一则Rust安全通告指出,他所使用的dotenv版本已无人维护,并推荐了替代方案dotenvy。

这个小插曲让他开始反思:这个依赖真的必不可少吗?他尝试后发现,仅仅35行代码便实现了他所需的核心功能。他由此提出一个普遍性的问题:当依赖项(尤其是那些看似“微不足道”的)不再维护或出现安全漏洞时,我们该如何应对?那些我们真正“需要”的复杂依赖,又隐藏着哪些风险?这不仅仅是功能问题,更关乎依赖的信任链和维护者的责任。

百万行代码的“冲击波”:一个“小项目”的真实体积

Vincent的忧虑不止于此。他以一个自认为“微不足道”的Web服务项目为例——该项目使用广受好评的异步运行时tokio和Web框架axum,主要功能是处理请求、解压文件和记录日志。

当他尝试使用cargo vendor将所有依赖项本地化时,并用代码行数统计工具tokei进行分析,结果令他大吃一惊:总代码行数高达360万行!而他自己编写的业务代码仅有约1000行。

他将此与Linux内核的2780万行代码进行对比,发现他这个“小项目”的依赖代码量已接近后者的七分之一。他不禁发问:如何审计如此庞大的代码量?我们引入的重量级依赖,其绝大部分功能是否是我们项目真正需要的?

Vincent的经历并非个案。Hacker News社区的讨论中,有开发者(如kion)指出,现代软件开发中‘库叠库’的现象十分普遍,每一层依赖可能只用到其功能的冰山一角,但最终却可能导致简单的应用膨胀到数百MB。更有甚者(如jiggawatts)通过计算发现,仅三层依赖的层层叠加,就可能导致最终应用中88%的代码是“死代码”或从未被真实业务逻辑触及的“幽灵代码”。

Rust依赖困境的“求解”:作者的困惑与社区的多元声音

面对如此庞大的依赖代码和潜在风险,该博主坦诚自己“没有答案”。他提及了社区中一些常见的讨论方向,例如扩展标准库的利弊、开发者自身的责任以及业界大厂的实践等。

Hacker News社区的讨论进一步丰富了这些思考:

  • 编译时优化是否足够? 许多评论提到了链接时优化(LTO)、Tree Shaking等技术在剔除未使用代码方面的作用。Rust基于LLVM的优化确实能在这方面做出贡献。然而,正如一些评论者指出的,这些优化并非“银弹”,对于动态分发或包含大量可选编译特性的复杂依赖,完美剥离未使用部分仍充满挑战。
  • 更细粒度的依赖控制: Rust的features机制为选择性编译提供了可能,但社区也在探索更根本的解决方案。有开发者甚至提出了“超细粒度符号和依赖”的设想,即每个语言构造都声明其精确依赖,按需构建最小代码集,尽管这在实现上极具颠覆性。
  • 工具链的局限与期望: Vincent指出Cargo目前难以精确追踪最终编译产物包含的代码。社区也期待更强大的工具来分析依赖树、识别冗余、评估安全风险。

最终,文章作者将问题抛给了社区:我们应该怎么办?

我们的启示:从Rust的“依赖之忧”看现代软件供应链

Vincent的博文真实地反映了现代软件开发中普遍存在的“依赖困境”——我们享受着开源生态带来的便利,但也面临着供应链安全、代码膨胀、维护性等一系列挑战。

从他的分享和社区的热烈讨论中,我们可以得到以下几点启示:

  1. 审慎评估依赖,警惕“依赖膨胀”的陷阱,拥抱适度“复制”: “不要为了碟醋包饺子”。在引入任何依赖前,都应评估其必要性、维护状态、社区活跃度以及潜在的安全风险。正如Go社区所倡导的“A little copying is better than a little dependency. (一点复制代码胜过一点点依赖)”,有时为了避免引入一个庞大或不稳定的依赖,适度复制代码,或者自己实现一个轻量级的核心功能,可能是更明智的选择。Go语言设计者之一的 Rob Pike 在其著名的演讲《On Bloat》中也曾深刻地警示过软件膨胀的危害,其中就包括了因过度或不必要依赖导致的复杂性增加和性能下降。Pike强调,真正的简洁和高效往往来自于对问题本质的深刻理解和对引入外部因素的克制。

  2. 理解依赖的“冰山效应”与供应链安全——真实的威胁就在身边: 一个看似简单的库,背后可能隐藏着庞大的间接依赖。我们需要关注整个依赖树的健康状况。更重要的是,正如Hacker News上一些开发者强调的,依赖的真正“恐惧”更多在于供应链安全和代码的可审查性。当我们的项目依赖数百万行来自互联网的未知代码时,如何确保没有恶意代码或严重漏洞被悄然引入?这绝非危言耸听!就在最近,Socket威胁研究团队便披露了三个恶意的Go模块 (github.com/truthfulpharm/prototransform, github.com/blankloggia/go-mcp, github.com/steelpoor/tlsproxy)。这些模块通过命名空间混淆或伪装诱导开发者引入,其内部包含高度混淆的恶意代码,在特定条件(目前主要针对Linux系统)下会下载并执行毁灭性的“磁盘擦除”脚本 (done.sh),直接向主磁盘写入零,导致数据被完全清零且无法恢复!这个案例血淋淋地提醒我们,供应链安全是每一个开发者都必须严肃对待的现实威胁。 这需要我们对信任链和维护者责任有更清醒的认识。

  3. 寻求更精细的控制与工具支持: 无论是语言特性(如Go的build tags、Rust的features)、包管理工具(如更智能的tree shaking),还是库本身的模块化设计,都应朝着让开发者能更精细控制最终产物的方向努力。同时,自动化工具在依赖分析、漏洞扫描、许可证合规等方面扮演着越来越重要的角色。

  4. 标准库与生态的平衡: Go语言的“大标准库”策略在一定程度上缓解了对外部依赖的过度渴求,但也带来了标准库自身迭代和灵活性的挑战。Rust选择了更小的标准库和更繁荣的社区生态。Hacker News上的讨论也反映了这种分歧:一部分开发者期望Rust能拥有更丰富的标准库,以减少对外部“寻寻觅觅”的困扰;而另一部分则担心这会扼杀生态活力,导致标准库“僵化”。这两种模式各有其历史成因和现实取舍,值得我们持续观察和学习,或许未来会出现一种更优的“官方认证扩展库”或“元库”的形态。

讨论:你如何看待现代软件的“依赖管理”?

这篇文章所转述的思考与社区的热议无疑为我们敲响了警钟。你在日常开发中(无论是Rust、Go还是其他语言),是否也曾遇到过类似的依赖管理难题?你认为当前包管理生态面临的最大挑战是什么?又有哪些值得推广的最佳实践或工具?

非常欢迎在评论区留下你的宝贵见解和经验分享!

  • 原文链接:https://vincents.dev/blog/rust-dependencies-scare-me
  • Socket.dev发现恶意Go模块:https://socket.dev/blog/wget-to-wipeout-malicious-go-modules-fetch-destructive-payload

面对复杂的依赖与潜藏的风险,如何系统性提升你的Go安全意识与底层掌控力?

近期Go恶意模块的“磁盘擦除”事件,再次凸显了深入理解依赖、掌握底层机制、构建安全软件的重要性。如果你渴望系统性地学习Go语言的深层原理(包括编译、链接、运行时),提升对第三方库的辨别与审计能力,并在实践中规避类似的安全“大坑”…

那么,我的 「Go & AI 精进营」知识星球 将是你不可或缺的伙伴!这里不仅有【Go原理课】、【Go进阶课】、【Go避坑课】助你洞悉语言本质,更有针对性的安全实践讨论和案例分析。我会亲自为你解答各种疑难问题,你还可以与众多对技术安全与底层有追求的Gopher们一同交流,共同构建更安全的Go生态。

立即扫码加入,为你的技术栈装上“安全防火墙”,在复杂的软件世界中行稳致远!
img{512x368}


商务合作方式:撰稿、出书、培训、在线课程、合伙创业、咨询、广告合作。如有需求,请扫描下方公众号二维码,与我私信联系。

如发现本站页面被黑,比如:挂载广告、挖矿等恶意代码,请朋友们及时联系我。十分感谢! Go语言第一课 Go语言进阶课 Go语言精进之路1 Go语言精进之路2 Go语言编程指南
商务合作请联系bigwhite.cn AT aliyun.com

欢迎使用邮件订阅我的博客

输入邮箱订阅本站,只要有新文章发布,就会第一时间发送邮件通知你哦!

这里是 Tony Bai的个人Blog,欢迎访问、订阅和留言! 订阅Feed请点击上面图片

如果您觉得这里的文章对您有帮助,请扫描上方二维码进行捐赠 ,加油后的Tony Bai将会为您呈现更多精彩的文章,谢谢!

如果您希望通过微信捐赠,请用微信客户端扫描下方赞赏码:

如果您希望通过比特币或以太币捐赠,可以扫描下方二维码:

比特币:

以太币:

如果您喜欢通过微信浏览本站内容,可以扫描下方二维码,订阅本站官方微信订阅号“iamtonybai”;点击二维码,可直达本人官方微博主页^_^:
本站Powered by Digital Ocean VPS。
选择Digital Ocean VPS主机,即可获得10美元现金充值,可 免费使用两个月哟! 著名主机提供商Linode 10$优惠码:linode10,在 这里注册即可免费获 得。阿里云推荐码: 1WFZ0V立享9折!


View Tony Bai's profile on LinkedIn
DigitalOcean Referral Badge

文章

评论

  • 正在加载...

分类

标签

归档



View My Stats