时间线显示的内容
该会话通过具有代表性的令牌计数演示了一个现实的流程:- 在您输入任何内容之前:CLAUDE.md、自动内存、MCP 工具名称和技能描述都加载到上下文中。您自己的设置可能会在此处添加更多内容,例如输出样式或来自
--append-system-prompt的文本,两者都以相同的方式进入系统提示。 - 当 Claude 工作时:每个文件读取都会添加到上下文中,路径范围的规则会自动与匹配的文件一起加载,并且PostToolUse hook在每次编辑后触发。
- 后续提示:子代理在其自己的单独上下文窗口中处理研究,因此大文件读取不会进入您的窗口。只有摘要和一个小的元数据预告片返回。
- 最后:
/compact用结构化摘要替换对话。大多数启动内容会自动重新加载;下表显示了每个机制会发生什么。
压缩后保留的内容
当长会话压缩时,Claude Code 会总结对话历史以适应上下文窗口。您的指令会发生什么取决于它们的加载方式:| 机制 | 压缩后 |
|---|---|
| 系统提示和输出样式 | 不变;不是消息历史的一部分 |
| 项目根目录 CLAUDE.md 和无范围规则 | 从磁盘重新注入 |
| 自动内存 | 从磁盘重新注入 |
带有 paths: frontmatter 的规则 | 丢失,直到再次读取匹配的文件 |
| 子目录中的嵌套 CLAUDE.md | 丢失,直到再次读取该子目录中的文件 |
| 调用的技能主体 | 重新注入,每个技能上限为 5,000 个令牌,总计 25,000 个令牌;最旧的首先删除 |
| Hooks | 不适用;hooks 作为代码运行,不是上下文 |
paths: frontmatter 或将其移动到项目根目录 CLAUDE.md。
技能主体在压缩后重新注入,但大型技能会被截断以适应每个技能的上限,一旦超过总预算,最旧的调用技能就会被删除。截断保留文件的开头,因此请将最重要的指令放在 SKILL.md 的顶部附近。
检查您自己的会话
该可视化使用代表性数字。要在任何时刻查看您的实际上下文使用情况,请运行/context 以获取按类别的实时分解和优化建议。运行 /memory 以检查在启动时加载了哪些 CLAUDE.md 和自动内存文件。