关于分支和� �记名称
大多数存储库都使用简单的分支名称,例如 main
或 update-icons
。 � �记名称通常也遵循基本� �式,例如版本号 v1.2.3
。 分支名称和� �签名称也可使用路径分隔符 (/
) 来表示结构,例如 area/item
或 level-1/level-2/level-3
。 除了一些例外 — 例如名称不以斜线开头或结尾,或者名称中有连续的斜线 — Git 对分支和� �签名称中可使用的字符� 乎没有限制。 有关详细信息,请参阅 Git 文档中的“git-check-ref-format”。
为什么需要对特殊字符进行转义
使用 CLI 时,您可能会遇到分支或� �记名称包含对 shell 环境具有特殊含义的特殊字符的情况。 要在 Git 命令中安全地使用这些字符,必须用引号或转义它们,否则该命令可能会产生意外效果。
例如,$
字符被许多 shell 用来引用变量。 大多数 shell 会将 hello-$USER
这� �的有效分支名称解释为等同于单词“hello”,后跟一个连字符,再后跟 USER
变量的当前值(而不是文字字符串 hello-$USER
)。 如果分支名称包含 $
字符,则必须阻止 shell 将其扩展为变量引用。 同� �,如果分支名称包含分号 (;
),大多数 shell 会将其解释为命令分隔符,� 此需要对其进行引用或转义。
如何对分支和� �记名称中的特殊字符进行转义
大多数带有特殊字符的分支和� �签名称都可通过将名称包含在单引号中来处理,例如 'hello-$USER'
。
- 在 Bash shell 中,将字符串括在单引号中可保留单引号中字符的文本值。
- Zsh 的行为类似于 Bash,但是可使用
RC_QUOTES
选项配置此行为。 - PowerShell 还会按字面意思处理单引号内的字符。
对于这些 shell,主要的例外是分支或� �记名称本身包含单个引号。 在这种情况下,您应该查阅 shell 的官方文档:
命名分支和� �记
如果可能,请创建不包含特殊字符的分支和� �记名称,� 为这些字符需要转义。 用于分支名称和� �记名称的安全默认字符集为:
- 英文字母(
a
-z
和A
-Z
) - 数字 (
0
-9
) - 有限的� �点字符集:
- 句点 (
.
) - 连字符 (
-
) - 下划线 (
_
) - 正斜� (
/
)
- 句点 (
为避免混淆,分支名称应以字母开头。