当前位置: 首页 > article >正文

Go Command 工作组成立:这几个用了十年的命令可能要被废!

大家好我是Tony Bai。在这个技术浪潮汹涌的时代Go 语言以其惊人的稳定性和向后兼容性著称。但稳定并不代表停滞。就在最近Go 核心团队内部悄然发生了一件大事他们正式成立了一个全新的 “Go Command 工作组Go Command Working Group”。这个工作组汇聚了 Go 工具链领域最核心的大神们如 Cherry Mui、Matloob、ThePudds 等。他们的使命非常明确对go命令集中那些最古老、最含糊、最容易引发开发者困惑的“历史遗留问题”进行一次彻底的“清理门户”。就在前几天这个“指挥部”的前两次闭门会议纪要以及随之而来的两份重磅提案Issue #78350 和 #78387被公之于众。当我读完这些提案和讨论后我意识到一场关于 Go 语言未来的“静默革命”已经打响。今天就让我们来拆解这场顶级大佬的闭门会议看看我们用了十年的几个“祖传命令”为什么即将面临被废除的命运。第一刀砍向go list ...这个“万能匹配”为何成了大坑如果你写过稍微复杂一点的 Go 项目甚至只是写过一些 Makefile你大概率见过go list ...。在早期go list ...中的这三个点的省略号...意味着“匹配所有Everything”。但在 Go Modules 时代这条命令成了一个彻头彻尾的“陷阱”。在最新的 Issue #78387 提案中工作组负责人 Matloob 毫不客气地指出“在Go 模块模式下go list ...几乎永远做不出用户期望它做的事”大佬辩论现场还原Matloob主刀人它试图列出构建列表中所有模块的所有包这会导致解析一大堆根本不需要的依赖。如果直接在模块下运行它甚至会因为找不到工作区依赖而直接抛出莫名其妙的错误。PJ Weinberger强烈支持废弃ThePudds模块图剪枝Pruning在Go 1.17引入后匹配模式的含义变得非常复杂连文档都没完全跟上。大家越来越搞不懂...到底代表什么了。为什么必须砍掉它在旧的 GOPATH 时代go list ...能简单粗暴地列出$GOPATH/src下的所有包。但在 Modules 时代你想要的其实是当前项目的所有包也就是go list ./...注意前面的./。直接用...会引发漫长且无意义的全局依赖解析甚至导致构建失败。更有意思的是核心成员 Sean Liao (seankhliao) 用 GitHub 搜索了一下发现有将近 6700 个 Makefile 或脚本里还写着...。但经过抽查发现这些代码大多是从几年前的旧教程里复制粘贴过来的实际上在现在的模块模式下它们本来就已经跑不通了。经过讨论工作组达成初步共识在模块模式下直接使用go list ...将会报错并被禁用。系统会提示你改用./...或者work模式。如果你公司的古老 CI 脚本里还有这个写法赶紧改第二刀GO111MODULEauto的黄昏彻底关上 GOPATH 的大门GO111MODULE这个环境变量是无数 Gopher 从 GOPATH 时代痛苦过渡到 Modules 时代的“阵痛记忆”。它有三个值on强制开启模块、off强制关闭、以及auto自动检测。在Issue #78350提案中工作组决定对auto下达最终的“死亡通知书”。大佬辩论现场还原Matloob我们提议将GO111MODULEauto的行为直接等同于on。实际上这就是把它给“移除”了。Cherry Mui安全与数据派我们应该现在就开启遥测Telemetry看看到底还有多少人在用auto。我们无法预测什么时候会需要这些数据。ThePudds社区观察家确实还有少数人比如只想在命令行随手编译一个单文件脚本不想建go.mod的人还在享受 GOPATH 模式。为什么必须砍掉autoauto的逻辑是如果当前或上层目录有go.mod就用模块模式否则就回退到 GOPATH 模式。这种“左右摇摆”的行为在十年前是伟大的过渡方案但在今天却成了巨大的累赘。Go 的工具链在启动时每次都要去猜自己到底在什么模式下运行。如果彻底砍掉auto即默认全局on编译器可以做大量的架构简化。更有趣的是在提案的评论区有开发者表示他们为了在旧 GOPATH 项目和新 Modules 项目间切换在全局环境变量里写死了GO111MODULEauto。但 Go 团队的决心是坚定的到了 2026 年如果你真的还在维护古老的 GOPATH 项目你应该显式地在那个目录下设置GO111MODULEoff。默认情况下大门已经向 GOPATH 彻底关闭。第三刀终结go.mod里的版本号“无意义内卷”除了上述两个直接废弃的命令会议纪要中还透露了一个极具前瞻性、也最能体现 Go 团队“工程哲学”的重磅提议关于go.mod文件中 Go 版本号的简化。如果你现在运行go mod init my-module生成的go.mod文件里会包含一个精确到补丁号Patch version的版本比如go 1.26.2。这引发了一个极其无聊却又在开源界反复上演的“内卷”每次 Go 发布一个新的小补丁版本Github Dependabot 这种自动化机器人就会疯狂地给全世界的开源项目提 PR要求把go.mod里的版本号也跟着升上去。大佬辩论现场还原ThePudds这种为了升级而升级的行为带来了巨大的“噪音Noise”却没有相应的收益。我们应该倡导一个最佳实践默认情况下go mod init应该只生成主次版本号如go 1.26补丁号应该是可选的且不推荐设置Cherry Mui安全视角等一下这需要跟安全团队确认。如果某个补丁修复了严重的安全漏洞漏扫工具会不会因为开发者没写补丁号而漏报ThePudds每个开发者都有自己本地的构建工具链决策权。仅仅因为 Go 出了个补丁并不意味着世界上每一个开源库都需要立刻被 Dependabot 强行更新一次go.mod文件。go.mod里的go指令核心作用是“启用语言的语法特性”。只要你的代码没用新语法写1.26就足够了。至于构建时到底用1.26.3还是1.26.8的编译器来保证安全那是执行构建动作的人或者 CI 系统该操心的事而不是由成千上万个基础库的go.mod文件来反向绑架。这项提议一旦落地将彻底终结无意义的 PR 轰炸让开源维护者重新获得清净。小结一场“静默的革命”Go Command 工作组的这两次会议没有像泛型那样引入任何惊天动地的新语法。但它对 Go 语言生态的影响可能比任何一个新特性都要深远。它像一个经验丰富的老园丁正在小心翼翼但又果断地修剪 Go 这棵大树上那些已经枯萎、或者长歪了的枝桠。砍掉go list ...是为了让模块查询的逻辑更清晰。砍掉GO111MODULEauto是为了让构建环境更具确定性。简化go.mod的补丁号是为了让整个生态的协作更高效。在这场“静默的革命”背后我们看到的是 Go 团队对“简单性、确定性、工程效率”这三大工程哲学一以贯之的坚守。Go 语言的伟大不在于它有多么强大的功能而在于它在过去十几年里拒绝了多少看似“合理”的坏品味。而这场“清理门户”才刚刚开始。资料链接https://github.com/golang/go/issues/78474 今日互动探讨在日常开发中你被 Go 命令行的哪些“反直觉”行为坑过对于废弃go list ...和GO111MODULEauto你是拍手叫好还是觉得会影响你的老项目欢迎在评论区分享你的看法如果本文对你有所帮助请帮忙点赞、推荐和转发点击下面标题干货- Go 1.26 中值得关注的几个变化从 new(expr) 真香落地、极致性能到智能工具链- 别再像 2015 年那样写 Go 了Modern Go 终极进化指南- Go mod init 降级撤回背后精英主义正在杀死 Go 社区的民主- “你装了 Go 1.26却写不了 Go 1.26 的代码”——复盘 go mod init 的降级风波- 前世今生从 GOPATH 的“混乱”到 Go Modules 的“秩序”- Go 1.17新特性详解module依赖图修剪与延迟module加载- Go 2026 路线图曝光SIMD、泛型方法与无 C 工具链 CGO —— 性能与表达力的双重飞跃 还在为“复制粘贴喂AI”而烦恼我的新极客时间专栏《AI原生开发工作流实战》将带你告别低效重塑开发范式驾驭AI Agent(Claude Code)实现工作流自动化从“AI使用者”进化为规范驱动开发的“工作流指挥家”扫描下方二维码开启你的AI原生开发之旅。

相关文章:

Go Command 工作组成立:这几个用了十年的命令可能要被废!

大家好,我是Tony Bai。在这个技术浪潮汹涌的时代,Go 语言以其惊人的稳定性和向后兼容性著称。但稳定,并不代表停滞。就在最近,Go 核心团队内部悄然发生了一件大事:他们正式成立了一个全新的 “Go Command 工作组&#…...

从数据采集到回放验证:ADTF 适配 ROS 的 ADAS 测试实践俳

一、简化查询 1. 先看一下查询的例子 /// /// 账户获取服务 /// /// /// public class AccountGetService(AccountTable table, IShadowBuilder builder) {private readonly SqlSource _source new(builder.DataSource);private readonly IParamQuery _accountQuery build…...

避开这些坑,你的Multisim音频放大电路仿真才能一次成功

避开这些坑,你的Multisim音频放大电路仿真才能一次成功 在电子电路设计领域,音频放大电路仿真是许多工程师和爱好者的必经之路。然而,即使是最简单的三级放大电路,在Multisim仿真环境中也常常会遇到各种意想不到的问题。本文将聚焦…...

聊一聊 C# 中的闭包陷阱:foreach 循环的坑你还记得吗?藏

. GIF文件结构 相比于 WAV 文件的简单粗暴,GIF 的结构要精密得多,因为它天生是为了网络传输而设计的(包含了压缩机制)。 当我们用二进制视角观察 GIF 时,它是由一个个 数据块(Block) 组成的&…...

Android USB 驱动程序安装指南:从下载到调试的全流程解析

1. 为什么需要安装Android USB驱动程序? 当你第一次把Android手机通过USB线连接到电脑时,可能会遇到设备无法识别的情况。这时候系统通常会提示"驱动程序未安装",导致你无法传输文件或者进行开发调试。我刚开始接触Android开发时就…...

Windows网络修复器

链接:https://pan.quark.cn/s/644d56bcec08Windows网络修复器是一款能够帮助用户恢复网络的工具,能够清理DNS本地缓存,并且能够帮助用户修复网络连接,让你能够更好的使用网络,有需要的用户不要错过了欢迎下载使用&…...

深度解析AI Agent的工具调用机制:注册发现、动态选择与执行链路设计

深度解析AI Agent的工具调用机制:注册发现、动态选择与执行链路设计 关键词 AI Agent, 工具调用, 注册发现, 动态选择, 执行链路, LLM, 函数调用 摘要 随着大型语言模型(LLM)的快速发展,AI Agent作为一种能够自主完成复杂任务的智能体正日益受到关注。本文将深度解析AI A…...

跨模态检索技术全景:从核心方法到前沿应用与挑战

1. 跨模态检索技术演进脉络 跨模态检索技术的发展可以追溯到早期的统计学习方法。最初的研究主要依赖**典型相关分析(CCA)**这类线性方法,通过寻找不同模态数据之间的线性关系来实现对齐。比如在2000年代初,研究者们用CCA处理文本…...

AI教育全面碾压传统教培:现状、挑战与转型路径

随着人工智能技术的爆发式发展,教育行业正经历一场前所未有的变革。AI教育培训正以惊人的速度重塑传统教育模式,从个性化学习到智能评估,从虚拟教师到自适应课程,AI正在全方位"碾压"传统教育培训体系。一、AI教育培训对…...

解决Pandas读取CSV时的ValueError:Usecols与列名不匹配的实战技巧

1. 为什么会出现Usecols与列名不匹配的错误 当你用Pandas读取CSV文件时,如果遇到"ValueError: Usecols do not match columns"这个错误,十有八九是因为列名匹配出了问题。我刚开始用Pandas时也经常踩这个坑,特别是当数据文件比较复…...

LumiPixel Canvas Quest多模态初探:结合文本描述生成角色设定图

LumiPixel Canvas Quest多模态初探:结合文本描述生成角色设定图 1. 多模态创作的新可能 最近试用LumiPixel Canvas Quest时,最让我惊喜的是它处理复杂文本描述的能力。不同于简单的文生图工具,这款模型真正展现了多模态理解的潜力——它能将…...

ESP32S2开发板变身USB网卡:从硬件连接到配网实战

1. 为什么需要把ESP32S2变成USB网卡? 最近在折腾智能家居项目时,发现很多嵌入式设备需要联网功能,但传统WiFi模块配置复杂且稳定性一般。偶然发现ESP32S2开发板居然能通过USB接口模拟网卡功能,实测下来简直打开了新世界的大门——…...

避坑指南:为MATLAB 2023b配置CCS12.2+C2000ware 4.03黄金开发环境

MATLAB 2023b与CCS12.2C2000ware 4.03开发环境配置全攻略 当工程师们开始搭建基于TI C2000和MATLAB的模型化设计工作流时,环境配置往往是第一个需要跨越的门槛。特别是对于MATLAB 2023b这样的新版本,选择与之匹配的工具链版本至关重要。本文将深入探讨如…...

Switch_lib:面向继电器控制的轻量级数字引脚时序管理库

1. Switch_lib 库深度解析:面向继电器控制的数字引脚时序管理方案在工业控制、智能家居和嵌入式自动化系统中,对数字输出引脚进行精确、可编程的时序控制是基础而关键的需求。典型场景包括:继电器驱动(如水泵启停、照明定时、加热…...

告别原生JDBC的繁琐:用DBUtils的QueryRunner和BeanHandler重构你的Servlet登录逻辑

从JDBC泥潭到DBUtils优雅实践:Servlet登录逻辑的重构艺术 登录功能作为Web应用的基石,其代码质量直接影响系统的安全性和可维护性。传统ServletJDBC方案虽然直接,但存在大量重复代码和资源管理隐患。让我们看看如何用Apache Commons DBUtils这…...

## 015、AutoSAR CP实战:配置存储栈(NvM,Fee,Ea)

深夜的产线问题 产线突然报过来一个诡异问题:车辆下电后重新上电,里程表数据偶尔会跳回三天前的数值。抓了三天Log,发现每当Flash擦除时电压有轻微波动,问题就复现。这直接把我们引向了存储栈的配置——NvM、Fee、Ea这套组合拳,任何一个参数配歪了,都是量产时的定时炸弹…...

PingCraft:从需求文档到可追踪工作项的 Agent 实践之路段

整体排查思路 我们的目标是验证以下三个环节是否正常: 登录成功时:服务器是否正确生成了Session并返回了包含正确 JSESSIONID的Cookie给浏览器。 浏览器端:浏览器是否成功接收并存储了该Cookie。 后续请求:浏览器在执行查询等操作…...

# 016、AutoSAR CP操作系统(OS)配置与任务调度:那个让我加班到凌晨三点的调度死锁

上周在联调ECU唤醒流程时,遇到一个诡异现象:系统唤醒后运行几分钟就卡死,仿真器显示所有任务都停在WaitEvent状态。抓了三天Trace才发现,是OS任务优先级配反了——高优先级任务等低优先级任务释放资源,低优先级任务又被中等优先级任务抢占,经典的优先级反转没处理好。今天…...

彻底告别OpenClaw使用焦虑:我给他装上了“透视眼”和“批量克隆模组岳

指令替换 项目需求:将加法指令替换为减法 项目目录如下 /MyProject ├── CMakeLists.txt # CMake 配置文件 ├── build/ #构建目录 │ └── test.c #测试编译代码 └── mypass2.cpp # pass 项目代码 一,测试代码示例 test.c // test.c #includ…...

Qwen3-ASR-1.7B部署教程:HTTPS反向代理配置保障Web服务安全访问

Qwen3-ASR-1.7B部署教程:HTTPS反向代理配置保障Web服务安全访问 语音识别技术正变得越来越普及,从会议记录到视频字幕,再到智能客服,它正在改变我们与机器交互的方式。Qwen3-ASR-1.7B作为一款高精度的开源语音识别模型&#xff0…...

微服务安全移动端架构

微服务安全移动端架构:构建高效可靠的移动应用 随着移动互联网的快速发展,移动应用的安全性和性能成为开发者关注的重点。微服务架构以其灵活性和可扩展性,成为构建现代移动应用的热门选择。如何在微服务架构下确保移动端的安全性&#xff0…...

过参数化如何重塑现代机器学习的性能边界

1. 过参数化:从理论禁区到性能引擎 第一次听说"模型参数比训练数据还多"时,我的反应和多数传统机器学习从业者一样——这简直是自寻死路。2016年调试ResNet时,明明加了Batch Normalization和L2正则,看着验证集loss曲线还…...

四路红外循迹模块的‘坑’我都替你踩了:Arduino小车硬件避坑与实战优化

四路红外循迹模块的‘坑’我都替你踩了:Arduino小车硬件避坑与实战优化 当你第一次尝试制作Arduino巡线小车时,可能会被各种硬件问题困扰:传感器读数不稳定、电机转动异常、电源干扰……这些问题往往让初学者感到挫败。本文将分享我在实际项目…...

Qwen2.5-7B-Instruct网络安全应用:智能威胁检测与分析

Qwen2.5-7B-Instruct网络安全应用:智能威胁检测与分析 1. 引言 网络安全运维团队每天都要面对海量的日志数据,传统的分析方法往往力不从心。安全工程师需要花费大量时间手动筛选日志、分析异常模式、编写威胁报告,这种重复性工作不仅效率低…...

辛顿 | 我习惯了房间里只有我一个人是对的

注:本文为 “辛顿 | 智者历程” 相关合辑。 略作重排,如有内容异常,请看原文。 X 热点|30 年冷板凳,诺贝尔物理学奖得主 Hinton 的 AI 往事 原创 Rika 适道 2024 年 10 月 9 日 11:13 北京 作者:Rika 编辑…...

数字丝路新基建:HAKUNA MATATA发布OpenClaw智能系统,为中非合作打造双向“数字龙虾“

——非洲驻华使馆专属智能发布系统暨中国企业对非智能决策平台正式上线【中国,北京/杭州,2026年4月12日】 在2024年中非合作论坛北京峰会精神持续深化落实、中非经贸合作迈向"真实亲诚"新时代的背景下,非洲综合服务平台HAKUNA MATA…...

口碑好的不锈钢彩涂板服务商

最近跟一个做钢结构厂房的老哥聊天,他跟我大倒苦水,说去年一个项目用的彩涂板,还没到一年,沿海的盐雾一吹,表面就开始起泡、褪色,甲方天天追着屁股后面要求返工,赔钱不说,信誉都快赔…...

LightOnOCR-2-1B效果对比:vs PaddleOCR、EasyOCR在多语言场景表现

LightOnOCR-2-1B效果对比:vs PaddleOCR、EasyOCR在多语言场景表现 当你需要从图片里提取文字时,是不是经常遇到这样的烦恼:中文识别还行,但一碰到英文、日文或者混合了多种语言的文档,准确率就直线下降?或…...

OpCore Simplify:如何用图形化工具快速完成黑苹果EFI配置?

OpCore Simplify:如何用图形化工具快速完成黑苹果EFI配置? 【免费下载链接】OpCore-Simplify A tool designed to simplify the creation of OpenCore EFI 项目地址: https://gitcode.com/GitHub_Trending/op/OpCore-Simplify 还在为复杂的OpenCo…...

怎么查询MongoDB中数组长度大于N的文档_基于索引的额外长度字段方案

MongoDB中用$expr$size查数组长度大于N的文档虽原生支持,但无法走索引,适合中小集合或配合其他可索引条件使用;而维护tags_length字段并建索引可实现高效范围查询,前提是严格保证写时一致性。用 $expr $size 直接查数组长度大于 …...