每个 Claude Code 会话都从一个全新的上下文窗口开始。两种机制可以跨会话传递知识:Documentation Index
Fetch the complete documentation index at: https://code.claude.com/docs/llms.txt
Use this file to discover all available pages before exploring further.
- CLAUDE.md 文件:你编写的指令,为 Claude 提供持久上下文
- 自动记忆:Claude 根据你的更正和偏好自己编写的笔记
- 编写和组织 CLAUDE.md 文件
- 使用
.claude/rules/将规则范围限定到特定文件类型 - 配置自动记忆,使 Claude 自动记笔记
- 故障排除,当指令未被遵循时
CLAUDE.md 与自动记忆
Claude Code 有两个互补的记忆系统。两者都在每次对话开始时加载。Claude 将它们视为上下文,而不是强制配置。你的指令越具体和简洁,Claude 遵循它们的一致性就越高。| CLAUDE.md 文件 | 自动记忆 | |
|---|---|---|
| 谁编写 | 你 | Claude |
| 包含内容 | 指令和规则 | 学习和模式 |
| 范围 | 项目、用户或组织 | 每个工作树 |
| 加载到 | 每个会话 | 每个会话(前 200 行或 25KB) |
| 用于 | 编码标准、工作流、项目架构 | 构建命令、调试见解、Claude 发现的偏好 |
CLAUDE.md 文件
CLAUDE.md 文件是 markdown 文件,为项目、你的个人工作流或整个组织为 Claude 提供持久指令。你用纯文本编写这些文件;Claude 在每个会话开始时读取它们。何时添加到 CLAUDE.md
将 CLAUDE.md 视为你写下你本来会重新解释的内容的地方。在以下情况下添加到它:- Claude 第二次犯同样的错误
- 代码审查发现 Claude 应该了解这个代码库的内容
- 你在聊天中输入的相同更正或澄清是你上个会话输入的
- 新队友需要相同的上下文才能提高生产力
选择 CLAUDE.md 文件的位置
CLAUDE.md 文件可以位于多个位置,每个位置有不同的范围。更具体的位置优先于更广泛的位置。| 范围 | 位置 | 目的 | 用例示例 | 共享对象 |
|---|---|---|---|---|
| 托管策略 | • macOS: /Library/Application Support/ClaudeCode/CLAUDE.md• Linux 和 WSL: /etc/claude-code/CLAUDE.md• Windows: C:\Program Files\ClaudeCode\CLAUDE.md | 由 IT/DevOps 管理的组织范围指令 | 公司编码标准、安全策略、合规要求 | 组织中的所有用户 |
| 项目指令 | ./CLAUDE.md 或 ./.claude/CLAUDE.md | 项目的团队共享指令 | 项目架构、编码标准、常见工作流 | 通过源代码控制的团队成员 |
| 用户指令 | ~/.claude/CLAUDE.md | 所有项目的个人偏好 | 代码样式偏好、个人工具快捷方式 | 仅你(所有项目) |
| 本地指令 | ./CLAUDE.local.md | 个人项目特定偏好;添加到 .gitignore | 你的沙箱 URL、首选测试数据 | 仅你(当前项目) |
设置项目 CLAUDE.md
项目 CLAUDE.md 可以存储在./CLAUDE.md 或 ./.claude/CLAUDE.md 中。创建此文件并添加适用于在项目上工作的任何人的指令:构建和测试命令、编码标准、架构决策、命名约定和常见工作流。这些指令通过版本控制与你的团队共享,因此请关注项目级标准而不是个人偏好。
编写有效的指令
CLAUDE.md 文件在每个会话开始时加载到上下文窗口中,与你的对话一起消耗令牌。上下文窗口可视化显示 CLAUDE.md 相对于其余启动上下文的加载位置。因为它们是上下文而不是强制配置,你编写指令的方式会影响 Claude 遵循它们的可靠性。具体、简洁、结构良好的指令效果最好。 大小:每个 CLAUDE.md 文件目标在 200 行以下。较长的文件消耗更多上下文并降低遵守度。如果你的指令变得很大,使用 路径范围规则 以便指令仅在 Claude 处理匹配文件时加载。你也可以将内容分割成 导入 以便组织,尽管导入的文件仍然加载并在启动时进入上下文窗口。 结构:使用 markdown 标题和项目符号来分组相关指令。Claude 扫描结构的方式与读者相同:有组织的部分比密集段落更容易遵循。 具体性:编写具体到足以验证的指令。例如:- “使用 2 空格缩进”而不是”正确格式化代码”
- “在提交前运行
npm test”而不是”测试你的更改” - “API 处理程序位于
src/api/handlers/”而不是”保持文件有组织”
.claude/rules/ 以删除过时或冲突的指令。在 monorepos 中,使用 claudeMdExcludes 跳过与你的工作无关的其他团队的 CLAUDE.md 文件。
导入其他文件
CLAUDE.md 文件可以使用@path/to/import 语法导入其他文件。导入的文件在启动时展开并加载到上下文中,与引用它们的 CLAUDE.md 一起。
允许相对路径和绝对路径。相对路径相对于包含导入的文件解析,而不是工作目录。导入的文件可以递归导入其他文件,最大深度为五跳。
要引入 README、package.json 和工作流指南,在你的 CLAUDE.md 中的任何地方使用 @ 语法引用它们:
CLAUDE.local.md。它与 CLAUDE.md 一起加载并以相同方式处理。将 CLAUDE.local.md 添加到你的 .gitignore 以便它不被提交;运行 /init 并选择个人选项会为你做这个。
如果你在同一存储库的多个 git worktrees 中工作,一个被 gitignore 的 CLAUDE.local.md 仅存在于你创建它的 worktree 中。要在 worktrees 中共享个人指令,改为从你的主目录导入文件:
.claude/rules/。
AGENTS.md
Claude Code 读取CLAUDE.md,而不是 AGENTS.md。如果你的存储库已经为其他编码代理使用 AGENTS.md,创建一个导入它的 CLAUDE.md,这样两个工具都可以读取相同的指令而无需重复。你也可以在导入下方添加 Claude 特定的指令。Claude 在会话开始时加载导入的文件,然后附加其余部分:
CLAUDE.md
CLAUDE.md 文件如何加载
Claude Code 通过从当前工作目录向上遍历目录树来读取 CLAUDE.md 文件,检查沿途的每个目录是否有CLAUDE.md 和 CLAUDE.local.md 文件。这意味着如果你在 foo/bar/ 中运行 Claude Code,它会从 foo/bar/CLAUDE.md、foo/CLAUDE.md 和沿途的任何 CLAUDE.local.md 文件加载指令。
所有发现的文件被连接到上下文中,而不是相互覆盖。在目录树中,内容从文件系统根目录向下排序到你的工作目录。对于 foo/bar/ 示例,foo/CLAUDE.md 在上下文中出现在 foo/bar/CLAUDE.md 之前,因此更接近你启动 Claude 的位置的指令最后被读取。在每个目录中,CLAUDE.local.md 在 CLAUDE.md 之后附加,因此你的个人笔记是 Claude 在该级别读取的最后内容。
Claude 还在当前工作目录下的子目录中发现 CLAUDE.md 和 CLAUDE.local.md 文件。它们不是在启动时加载,而是在 Claude 读取这些子目录中的文件时包含。
如果你在一个大型 monorepo 中工作,其他团队的 CLAUDE.md 文件被拾取,使用 claudeMdExcludes 跳过它们。
块级 HTML 注释(<!-- maintainer notes -->)在 CLAUDE.md 文件中在内容注入到 Claude 的上下文之前被剥离。使用它们为人类维护者留下笔记,而不在它们上花费上下文令牌。代码块内的注释被保留。当你直接用 Read 工具打开 CLAUDE.md 文件时,注释保持可见。
从其他目录加载
--add-dir 标志使 Claude 可以访问主工作目录外的其他目录。默认情况下,不加载这些目录中的 CLAUDE.md 文件。
要也从其他目录加载记忆文件,设置 CLAUDE_CODE_ADDITIONAL_DIRECTORIES_CLAUDE_MD 环境变量:
CLAUDE.md、.claude/CLAUDE.md、.claude/rules/*.md 和 CLAUDE.local.md。如果你从 --setting-sources 中排除 local,CLAUDE.local.md 会被跳过。
使用 .claude/rules/ 组织规则
对于较大的项目,你可以使用 .claude/rules/ 目录将指令组织到多个文件中。这使指令保持模块化并更容易让团队维护。规则也可以 范围限定到特定文件路径,因此它们仅在 Claude 处理匹配文件时加载到上下文中,减少噪音并节省上下文空间。
规则在每个会话或打开匹配文件时加载到上下文中。对于不需要始终在上下文中的特定任务指令,改用 skills,它仅在你调用它们或 Claude 确定它们与你的提示相关时加载。
设置规则
在你的项目的.claude/rules/ 目录中放置 markdown 文件。每个文件应涵盖一个主题,具有描述性文件名,如 testing.md 或 api-design.md。所有 .md 文件都被递归发现,因此你可以将规则组织到子目录中,如 frontend/ 或 backend/:
paths frontmatter 的规则在启动时加载,优先级与 .claude/CLAUDE.md 相同。
特定路径的规则
规则可以使用带有paths 字段的 YAML frontmatter 范围限定到特定文件。这些条件规则仅在 Claude 处理与指定模式匹配的文件时适用。
paths 字段的规则无条件加载并适用于所有文件。路径范围规则在 Claude 读取与模式匹配的文件时触发,而不是在每次工具使用时。
在 paths 字段中使用 glob 模式按扩展名、目录或任何组合匹配文件:
| 模式 | 匹配 |
|---|---|
**/*.ts | 任何目录中的所有 TypeScript 文件 |
src/**/* | src/ 目录下的所有文件 |
*.md | 项目根目录中的 Markdown 文件 |
src/components/*.tsx | 特定目录中的 React 组件 |
使用符号链接跨项目共享规则
.claude/rules/ 目录支持符号链接,因此你可以维护一组共享规则并将它们链接到多个项目中。符号链接被解析并正常加载,循环符号链接被检测并优雅处理。
此示例链接共享目录和单个文件:
用户级规则
~/.claude/rules/ 中的个人规则适用于你机器上的每个项目。使用它们来处理不是项目特定的偏好:
为大型团队管理 CLAUDE.md
对于在团队中部署 Claude Code 的组织,你可以集中指令并控制加载哪些 CLAUDE.md 文件。部署组织范围的 CLAUDE.md
组织可以部署一个集中管理的 CLAUDE.md,适用于机器上的所有用户。此文件不能被个人设置排除。在托管策略位置创建文件
- macOS:
/Library/Application Support/ClaudeCode/CLAUDE.md - Linux 和 WSL:
/etc/claude-code/CLAUDE.md - Windows:
C:\Program Files\ClaudeCode\CLAUDE.md
使用你的配置管理系统部署
使用 MDM、Group Policy、Ansible 或类似工具在开发者机器上分发文件。有关其他组织范围配置选项,请参阅 托管设置。
| 关注点 | 配置在 |
|---|---|
| 阻止特定工具、命令或文件路径 | 托管设置:permissions.deny |
| 强制沙箱隔离 | 托管设置:sandbox.enabled |
| 环境变量和 API 提供商路由 | 托管设置:env |
| 身份验证方法和组织锁定 | 托管设置:forceLoginMethod、forceLoginOrgUUID |
| 代码样式和质量指南 | 托管 CLAUDE.md |
| 数据处理和合规提醒 | 托管 CLAUDE.md |
| Claude 的行为指令 | 托管 CLAUDE.md |
排除特定的 CLAUDE.md 文件
在大型 monorepos 中,祖先 CLAUDE.md 文件可能包含与你的工作无关的指令。claudeMdExcludes 设置让你按路径或 glob 模式跳过特定文件。
此示例排除顶级 CLAUDE.md 和来自父文件夹的规则目录。将其添加到 .claude/settings.local.json 以使排除保持本地到你的机器:
claudeMdExcludes。数组跨层合并。
托管策略 CLAUDE.md 文件不能被排除。这确保组织范围指令始终适用,无论个人设置如何。
自动记忆
自动记忆让 Claude 跨会话积累知识,无需你编写任何内容。Claude 在工作时为自己保存笔记:构建命令、调试见解、架构笔记、代码样式偏好和工作流习惯。Claude 不会每个会话都保存内容。它根据信息在未来对话中是否有用来决定什么值得记住。自动记忆需要 Claude Code v2.1.59 或更高版本。使用
claude --version 检查你的版本。启用或禁用自动记忆
自动记忆默认开启。要切换它,在会话中打开/memory 并使用自动记忆切换,或在你的项目设置中设置 autoMemoryEnabled:
CLAUDE_CODE_DISABLE_AUTO_MEMORY=1。
存储位置
每个项目在~/.claude/projects/<project>/memory/ 获得自己的记忆目录。<project> 路径来自 git 存储库,因此同一存储库中的所有 worktrees 和子目录共享一个自动记忆目录。在 git 存储库外,改用项目根目录。
要将自动记忆存储在不同位置,在你的用户或本地设置中设置 autoMemoryDirectory:
.claude/settings.json)接受,以防止共享项目将自动记忆写入重定向到敏感位置。
目录包含一个 MEMORY.md 入口点和可选的主题文件:
MEMORY.md 充当记忆目录的索引。Claude 在你的会话中读取和写入此目录中的文件,使用 MEMORY.md 跟踪存储的内容。
自动记忆是机器本地的。同一 git 存储库中的所有 worktrees 和子目录共享一个自动记忆目录。文件不在机器或云环境之间共享。
它如何工作
MEMORY.md 的前 200 行或前 25KB(以先到者为准)在每次对话开始时加载。第 200 行之外的内容在会话开始时不加载。Claude 通过将详细笔记移到单独的主题文件中来保持 MEMORY.md 简洁。
此限制仅适用于 MEMORY.md。CLAUDE.md 文件无论长度如何都完整加载,尽管较短的文件产生更好的遵守度。
主题文件如 debugging.md 或 patterns.md 在启动时不加载。Claude 在需要信息时使用其标准文件工具按需读取它们。
Claude 在你的会话中读取和写入记忆文件。当你在 Claude Code 界面中看到”Writing memory”或”Recalled memory”时,Claude 正在主动更新或读取 ~/.claude/projects/<project>/memory/。
审计和编辑你的记忆
自动记忆文件是纯 markdown,你可以随时编辑或删除。运行/memory 从会话中浏览和打开记忆文件。
使用 /memory 查看和编辑
/memory 命令列出在你当前会话中加载的所有 CLAUDE.md、CLAUDE.local.md 和规则文件,让你切换自动记忆开或关,并提供打开自动记忆文件夹的链接。选择任何文件在你的编辑器中打开它。
当你要求 Claude 记住某些内容时,如”总是使用 pnpm,而不是 npm”或”记住 API 测试需要本地 Redis 实例”,Claude 将其保存到自动记忆。要改为添加指令到 CLAUDE.md,直接要求 Claude,如”将其添加到 CLAUDE.md”,或通过 /memory 自己编辑文件。
故障排除记忆问题
这些是 CLAUDE.md 和自动记忆最常见的问题,以及调试步骤。Claude 不遵循我的 CLAUDE.md
CLAUDE.md 内容作为用户消息在系统提示之后传递,而不是系统提示本身的一部分。Claude 读取它并尝试遵循它,但没有严格遵守的保证,特别是对于模糊或冲突的指令。 要调试:- 运行
/memory验证你的 CLAUDE.md 和 CLAUDE.local.md 文件被加载。如果文件未列出,Claude 看不到它。 - 检查相关 CLAUDE.md 是否在为你的会话加载的位置(参见 选择 CLAUDE.md 文件的位置)。
- 使指令更具体。“使用 2 空格缩进”比”格式化代码很好”效果更好。
- 查找跨 CLAUDE.md 文件的冲突指令。如果两个文件为相同行为提供不同的指导,Claude 可能会任意选择一个。
--append-system-prompt。这必须在每次调用时传递,因此它更适合脚本和自动化而不是交互式使用。
我不知道自动记忆保存了什么
运行/memory 并选择自动记忆文件夹来浏览 Claude 保存的内容。一切都是纯 markdown,你可以读取、编辑或删除。
我的 CLAUDE.md 太大了
超过 200 行的文件消耗更多上下文并可能降低遵守度。使用 路径范围规则 仅在 Claude 处理匹配文件时加载指令,或修剪不是每个会话都需要的内容。分割到@path 导入 有助于组织,但不会减少上下文,因为导入的文件在启动时加载。
在 /compact 后指令似乎丢失了
项目根 CLAUDE.md 在压缩中存活:在 /compact 之后,Claude 从磁盘重新读取它并将其重新注入到会话中。子目录中的嵌套 CLAUDE.md 文件不会自动重新注入;它们在 Claude 下次读取该子目录中的文件时重新加载。
如果指令在压缩后消失,它要么仅在对话中给出,要么位于尚未重新加载的嵌套 CLAUDE.md 中。将仅对话的指令添加到 CLAUDE.md 以使其持久化。有关完整的细分,请参阅 什么在压缩中存活。
有关大小、结构和具体性的指导,请参阅 编写有效的指令。
相关资源
- 调试你的配置:诊断为什么 CLAUDE.md 或设置未生效
- Skills:打包按需加载的可重复工作流
- Settings:使用设置文件配置 Claude Code 行为
- Subagent 记忆:让 subagents 维护自己的自动记忆