惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

酷 壳 – CoolShell
酷 壳 – CoolShell
H
Hacker News: Front Page
P
Palo Alto Networks Blog
T
ThreatConnect
Apple Machine Learning Research
Apple Machine Learning Research
博客园_首页
T
True Tiger Recordings
P
Privacy & Cybersecurity Law Blog
B
Blog
IT之家
IT之家
Last Week in AI
Last Week in AI
F
Full Disclosure
Hacker News: Ask HN
Hacker News: Ask HN
C
Comments on: Blog
Microsoft Azure Blog
Microsoft Azure Blog
C
Cybersecurity and Infrastructure Security Agency CISA
Microsoft Security Blog
Microsoft Security Blog
博客园 - 【当耐特】
N
News and Events Feed by Topic
NISL@THU
NISL@THU
腾讯CDC
雷峰网
雷峰网
Security Latest
Security Latest
李成银的技术随笔
M
Microsoft Research Blog - Microsoft Research
L
LangChain Blog
L
Lohrmann on Cybersecurity
cs.CL updates on arXiv.org
cs.CL updates on arXiv.org
C
Check Point Blog
Y
Y Combinator Blog
Recent Announcements
Recent Announcements
博客园 - Franky
N
News | PayPal Newsroom
V
V2EX
A
About on SuperTechFans
The Register - Security
The Register - Security
月光博客
月光博客
奇客Solidot–传递最新科技情报
奇客Solidot–传递最新科技情报
Google Online Security Blog
Google Online Security Blog
MyScale Blog
MyScale Blog
Cisco Talos Blog
Cisco Talos Blog
Vercel News
Vercel News
WordPress大学
WordPress大学
C
Cyber Attacks, Cyber Crime and Cyber Security
The Hacker News
The Hacker News
IntelliJ IDEA : IntelliJ IDEA – the Leading IDE for Professional Development in Java and Kotlin | The JetBrains Blog
IntelliJ IDEA : IntelliJ IDEA – the Leading IDE for Professional Development in Java and Kotlin | The JetBrains Blog
爱范儿
爱范儿
A
Arctic Wolf
L
LINUX DO - 最新话题
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More

暗无天日

TIL: minibuffer 激活时也能操作其他窗口 - 暗无天日 读:Tramp改了配置怎么不生效 - 暗无天日 读:为 project.el 写一个自定义后端 - 暗无天日 读:AI 时代的敏捷开发 - 暗无天日 TIL: 给 dired 异步命令加 nohup,让外部程序活过 Emacs 退出 TIL: elisp-fontify-semantically——让 Emacs 看懂你的 Elisp 代码 TIL-etags扫描外部库头文件 - 暗无天日 读:The Many Faces of flet——Elisp 局部函数的三种写法 读:df 与 du——为什么两个磁盘用量命令数字对不上 - 暗无天日 TIL-可观测性工具的成本盲区 - 暗无天日 TIL: 把 Emacs Buffer 打印成图片 读:gamegrid.el——Emacs 内置游戏是怎么写出来的 - 暗无天日 TIL: MCP 服务器不到 20 行 Python 就能写出来 TIL-AI 工具普及后的组织观察 - 暗无天日 读:当 Agent 开始写数据库——六个防御模式 - 暗无天日 读:右键菜单——Elisp 开发的隐藏利器 - 暗无天日 读:Git 仓库里的隐藏配置文件 - 暗无天日 读:20条软件工程定律 - 暗无天日 读:编译高性能 Emacs - 暗无天日 读:为什么我在终端里待了十年——一个 Emacs 用户的 GUI 观察 读:Event Sourcing——让你的数据库记住每一次变更 - 暗无天日 读:数据管道中Schema变更的四种形状 - 暗无天日 读:SES——Emacs内置的简易电子表格 - 暗无天日 TIL: 用 parallel 加速 rsync 迁移海量小文件 TIL:给 AI 一个更小的世界——技术选型的上下文窗口约束 - 暗无天日 读:emacs chat 技巧拾遗——从 bandali 的配置里捡到的那些技巧 读:当 Agent 成为生产调用者——四个被打破的运维假设 - 暗无天日 TIL: describe-personal-keybindings 查看你的自定义按键 - 暗无天日 读:Linux 创建指定大小文件的三种方式——dd、fallocate 与 truncate - 暗无天日 读:Yazi——在终端里管理文件的新选择 - 暗无天日 读:软件测试的反馈视角——CLEAR 原则从测试到运维 - 暗无天日 MobileOrg Android:从 API 17 迁移到 API 34 的实战记录 TIL:微服务与复杂度守恒——从单体到分布式的代价转移 - 暗无天日 读:MCP 时代的安全威胁——幻觉权限与三道防线 - 暗无天日 读:超越对话——用 Skills 和 Agents 工程化上下文 TIL:用 :box 给 mode-line 加内边距 org-mobile-push 卡顿排查实战:从黑盒到字节码反编译 - 暗无天日 读:用 LLM 重构遗留代码——三个陷阱与一套方法 - 暗无天日 读:AI 辅助编程的三种错误用法 - 暗无天日 读:Before GitHub - 暗无天日 读:AI in Software Architecture - 暗无天日 读:把成本当作 SLI - 暗无天日 TIL: 用进程树展开定位被脚本包装的 JVM 进程 - 暗无天日 读:Linux 删文件的真相——用 /proc 恢复被进程持有的已删除文件 - 暗无天日 读:Choosing a Python Logging Library in 2026 Emacs buffer 导出:五种方案对比 - 暗无天日 TIL: flymake 错误跳转加入 Evil 跳转列表 TIL: 用 Org-mode 列表管理选择题题库 - 暗无天日 读:sysstat 诊断链——从 sar 到 pidstat 的排查路径 读:理论靠谱,生产翻车的六个集成模式 - 暗无天日 读:双写问题——@Transactional 给不了的跨系统一致性 - 暗无天日 读:PostgreSQL 随机测试数据生成——从快速造数到自动化填充 - 暗无天日 读:逆萨丕尔-沃夫假说与编程语言 - 暗无天日 读:理解 MCP 架构——LLM 直接调 API 与 MCP 协议的对比 读:Emacs 连接数据库时密码放哪里 - 暗无天日 TIL:watch 命令的几个遗漏技巧 - 暗无天日 TIL:Python 3.15 的 sentinel() 内置函数 读:7 Techniques That Supercharged My Claude-Assisted Development 读:AI 编码代理的四种工作流 - 暗无天日 读:Agent 的瓶颈不在模型,在基础设施 - 暗无天日 读:EvoForge——用群体进化优化 AI Agent - 暗无天日 TIL:Google Stitch 的 DESIGN.md,给 AI 读的设计系统说明书 Emacs 批量搜索替换:从场景到命令 - 暗无天日 TIL: image-mode 的 header-line 中显示图片尺寸 dotfile仓库大扫除:清理过时的配置 - 暗无天日 读:The Art of Logging——日志规范清单 - 暗无天日 从CSS选择器到自然语言:网页自动化的两种范式与取舍框架 - 暗无天日 TIL-用 curl + w3m + awk 从 HTML 表格提取数据 读:Shell脚本安全编码的五条铁律 - 暗无天日 读:Emacs newcomers-presets theme —— 30+ 项新手预设一览 读:Protesilaos 的 Emacs 合理默认配置 —— 兼与 newcomers-presets 对比 控制 Bash 历史记录的 6 个场景 读:AI Agent 安全日志——从可见性与隐私的两难说起 - 暗无天日 读:AI Agent 生产化——一份从原型到上线的速查清单 - 暗无天日 读:LLM 生产环境六种失败原型——基准测试无法预测的那些故障 - 暗无天日 读:Prompt Injection 五层纵深防御——从输入过滤到审计追踪 - 暗无天日 读:为什么所有 Prompt Injection 防御都会被攻破——以及架构上该怎么办 - 暗无天日 读:JVM 后端性能调优备忘——从一次生产事故中学到的优化要点 - 暗无天日 读:Java 容器化——从 Fat JAR 到高效 Docker 镜像 读:整洁代码的几个通用原则——从 Go 生态看起 - 暗无天日 读:规则引擎——从 if-else 到业务规则管理 - 暗无天日 AI写作的语言指纹——如何让文字不那么像机器 - 暗无天日 读:50 条 Claude Code 技巧——一个工程经理的六个月使用心得 读:AI 辅助开发为什么让 E2E 测试更有价值 - 暗无天日 读:在Emacs中使用Claude Code(Spacemacs适配版) - 暗无天日 Claude Code 背后的工程哲学——读 Agent Harness Engineering 读:Agent Harness Engineering——AI 智能体不只是模型,还有套件 - 暗无天日 browser-harness:让 AI 直接接管你的浏览器 - 暗无天日 读:Security-First CI/CD —— DevSecOps 自动化实践指南 TIL: 数字小键盘的小数点陷阱与行内算术求值 - 暗无天日 读:Immutability 不是万能药,它是一种权衡 - 暗无天日 Conducty:给 Claude Code 加上项目记忆和并行执行能力 - 暗无天日 读 — GitHub Trending 里的 Claude Code 技能包 读 — Prompt Caching 省钱指南 TIL: Emacs 中那些跟鼠标配合的冷门快捷键 - 暗无天日 读:Anvil——把 Emacs 变成 AI 的工具服务器 读:Emacs 代码折叠终极指南 - 暗无天日 读:Clojure 搭车客指南 - 暗无天日 git推送失败后恢复仓库损坏的完整记录 - 暗无天日 多智能体系统的两个有效模式——以及对 Claude Code 用户的启示 - 暗无天日
ANSI 转义码的标准化现状 - 暗无天日
2026-04-17 · via 暗无天日

终端之所以能显示彩色文字、响应鼠标、复制到剪贴板,都是靠 ANSI 转义码实现的。但转义码到底有没有标准?为什么有时候不生效? Julia Evans 的这篇博文(Standards for ANSI escape codes) 梳理了转义码的标准化现状:有哪些标准、标准之间是什么关系、终端应用开发者面临什么选择。

什么是转义码

你在终端里按左方向键时,终端发送的其实是 ^[[D —— 这就是一个转义码。它的第一个字符是"Escape"字符,通常写作 ESC\x1b\E\033^[

转义码是终端模拟器与终端中运行的程序之间的通信方式,分为两类:

  1. 输入码 :终端模拟器发送的,比如左方向键 ESC[D , Ctrl+左方向键 ESC[1;5D ,鼠标点击 ESC[M :3
  2. 输出码 :程序输出的,用于改变文字颜色、移动光标、清屏、隐藏光标、复制到剪贴板、设置窗口标题等

可以在终端中直接体验:

echo -e "\033[31m这是红色文字\033[0m"
echo -e "\033[5;10H把光标移到第5行第10列"
echo -e "\033]0;新窗口标题\007"

那么这些转义码有标准吗?有,但标准不止一个,而且没有一个能覆盖所有场景。

ECMA-48

最早的转义码标准是 ECMA-48 ,最早发布于 1976 年。它做了两件事:

  1. 定义了转义码的通用 格式 ,比如 CSI 序列( ESC[ + 内容)和 OSC 序列( ESC] + 内容)
  2. 定义了具体的转义码,比如"光标左移"是 ESC[D ,"文字变红"是 ESC[31m

ECMA-48 的格式是可扩展的,允许后续定义更多转义码。但很多今天常用的转义码并不在其中——比如 vim、htop、tmux 中常用的鼠标操作,ECMA-48 就没有定义。

ECMA-48 覆盖不到的部分,被另一个来源填补了。

xterm 控制序列

有些广泛使用的转义码不在 ECMA-48 中:

  • 启用鼠标报告(你在终端的哪里点击了?)
  • bracketed paste(你粘贴了文本还是手动输入的?)
  • OSC 52(终端应用用来复制文本到系统剪贴板)

这些功能大多源自 xterm,记录在 XTerm Control Sequences 文档中,并被其他终端模拟器广泛实现。这个列表严格来说不是标准,但 xterm 极具影响力,因此成了事实标准。

OSC 52 是个特别实用的例子。OSC 是 ESC] 开头的转义码大类(Operating System Command),52 是"剪贴板操作"的编号。它的格式是 ESC]52;c;<base64编码的文本>ESC\ ,其中 c 表示 system clipboard(还有 p 表示 primary selection)。

远程服务器上的程序本来无法访问你本地的剪贴板,但通过 OSC 52,程序发出转义序列,你的终端模拟器收到后把内容写入本地剪贴板。Vim、tmux 等工具都支持配置 OSC 52。

printf "\033]52;c;%s\007" "$(echo -n '要复制的文本' | base64)"

terminfo 数据库

上世纪 80 年代,终端之间对转义码支持的差异非常大。为了应对这个问题,出现了 terminfo 数据库,记录各种终端支持的转义码。

terminfo 的标准叫 X/Open Curses ,定义了数据库格式和访问数据库的 C 库接口(curses)。

你可以查看系统上所有终端的"清屏"转义码:

for term in $(toe -a | awk '{print $1}')
do
  echo "$term"
  infocmp -1 -T "$term" 2>/dev/null | grep 'clear=' | sed 's/clear=//g;s/,//g'
done

现代系统上的 terminfo 数据库由 ncurses 管理。

有了标准(ECMA-48、xterm)和适配层(terminfo),终端应用开发者面前的问题是:到底该用哪个?

程序该不该用 terminfo

终端应用处理转义码有两种主要策略:

  1. 使用 terminfo 数据库,根据 TERM 环境变量决定使用哪些转义码(Fish 采用这种方式)
  2. 确定一组"通用"转义码,硬编码到程序中

选择策略 2 的项目不少:kakoune、python-prompt-toolkit、linenoise、libvaxis、chalk 等。

为什么有人不用 terminfo 呢?一位 Fish 维护者的 长文吐槽 值得一看,核心观点是: terminfo 的工作在过去极其重要,但现在已经不是了。

terminfo 在 2025 年仍有支持者,理由也站得住脚:

  • 有人期望通过 TERM 环境变量控制程序行为(比如 TERM=dumb ),在后 terminfo 时代没有标准替代方案
  • 终端之间的差异虽然比 80 年代小了,但远没有消失:图形终端、Linux 帧缓冲控制台、串口控制台、Emacs shell 模式等各有不同
  • 没有标准定义什么是"通用"转义码集合,有些程序使用的转义码其实并不够通用

那如果走策略 2,这个"通用集合"到底是什么?目前看来是以下三者的交集:

  • VT100 支持的码(部分已不适用于现代终端)
  • ECMA-48 定义的码(同样有部分过时)
  • xterm 支持的码(并非全部被广泛支持)

实际上可能最终还是"找出用户最常用的终端模拟器,然后在那些终端上测试"——跟 Web 开发者决定用哪些 CSS 特性一样。

Web 有 Can I useBaseline 这样的兼容性参考,终端没有对应的工具。 terminfo 理论上应该扮演这个角色,但新终端功能的加入经常要等 10 年以上,严重限制了它的实用性。

这种困境并非终端独有——Web 也经历过类似的问题。

terminfo 与 User Agent 检测

ncursesTERM 环境变量决定转义码的方式,跟 Web 服务器根据浏览器 User Agent 返回不同版本的网页很像。

结果也类似——iTerm2 把自己报告为 xterm-256color ,就像 Safari 的 User Agent 是一串以 Mozilla/5.0 开头的字符串。两者都是在绕过不够好的检测机制。

Web 最终放弃了 User Agent 检测,转向标准化。但终端领域比 Web 碎片化更严重,资金也更少,能否走同样的路还不好说。