时间线显示的内容
该会话通过具有代表性的令牌计数演示了一个现实的流程:- 在您输入任何内容之前: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 的顶部附近。
当您的上下文填满时
Claude Code 在您接近限制时自动压缩,因此完整的上下文窗口不会结束您的会话。自动传递的工作方式与时间线中的/compact 步骤相同。有关它保留的内容,请参阅当上下文填满时。
您也可以在自动传递运行之前采取行动:
- 带有焦点的压缩:在开始长时间的新任务之前,运行带有指令的
/compact,例如/compact focus on the auth bug fix。摘要保留您选择的内容,而不是自动传递猜测的重要内容。 - 在任务之间清除:切换到不相关的工作时运行
/clear。旧对话会挤出您接下来需要的文件,并在每条消息上花费令牌。 - 委托大型读取:将研究发送给子代理,以便文件内容保留在其上下文窗口中,而不是您的。
[1m] 模型变体,请参阅扩展上下文。Sonnet 5 以 1M 运行,无需选择 [1m] 变体;有关其自动压缩阈值和 LLM 网关异常,请参阅Sonnet 5 上下文窗口。压缩在更大的限制下以相同的方式工作。
检查您自己的会话
该可视化使用代表性数字。要在任何时刻查看您的实际上下文使用情况,请运行/context 以获取按类别的实时分解和优化建议。运行 /memory 以检查在启动时加载了哪些 CLAUDE.md 和自动内存文件。