git-add[-all|-A]和git-add.之间有什么区别。?


当前回答

此答案仅适用于Git 1.x版本。有关Git 2.x版本,请参阅其他答案。


摘要:

gitadd-A阶段所有更改git添加。暂存新文件和修改,而不删除(在当前目录及其子目录上)。gitadd-u阶段修改和删除,无需新文件


详细信息:

git-add-A相当于git-add。;git-add-u。

关于gitadd的要点。它查看工作树,并将所有这些路径添加到已阶段的更改中,如果这些更改已更改或是新的且未被忽略,则不会阶段任何“rm”操作。

gitadd-u查看所有已跟踪的文件,如果这些文件不同或已被删除,则对这些文件进行更改。它不添加任何新文件,只对已跟踪的文件进行更改。

gitadd-A是实现这两个目的的便捷快捷方式。

您可以使用以下方式测试差异(注意,对于Git 2.x版本,您的Git-add.Git状态输出将不同):

git init
echo Change me > change-me
echo Delete me > delete-me
git add change-me delete-me
git commit -m initial

echo OK >> change-me
rm delete-me
echo Add me > add-me

git status
# Changed but not updated:
#   modified:   change-me
#   deleted:    delete-me
# Untracked files:
#   add-me

git add .
git status

# Changes to be committed:
#   new file:   add-me
#   modified:   change-me
# Changed but not updated:
#   deleted:    delete-me

git reset

git add -u
git status

# Changes to be committed:
#   modified:   change-me
#   deleted:    delete-me
# Untracked files:
#   add-me

git reset

git add -A
git status

# Changes to be committed:
#   new file:   add-me
#   modified:   change-me
#   deleted:    delete-me

其他回答

git添加。等于git add-A。仅将当前文件夹和子文件夹中的文件添加到索引中。

gitadd-A将工作树中所有文件夹的文件添加到索引中。

注:有关Git 2.0的信息(2014-05-28)。

一个更精炼的快速答案:

两者都在下面(与git add--all相同)

git add -A

暂存新的+修改的文件

git add .

阶段已修改+已删除文件

git add -u

Git 2.0改变了一切(2014-05-28):

-A现在是默认值旧的行为现在可以使用--ignore删除。命令行上没有路径的子目录中的gitadd-u和gitadd-A对整个树进行操作。

因此,对于Git 2,答案是:

git添加。和git-add-A。在当前目录中添加新的/修改的/删除的文件gitadd—忽略删除。在当前目录中添加新的/修改的文件git add-u。在当前目录中添加修改/删除的文件如果没有圆点,则添加项目中的所有文件,而不考虑当前目录。

此答案仅适用于Git 1.x版本。有关Git 2.x版本,请参阅其他答案。


摘要:

gitadd-A阶段所有更改git添加。暂存新文件和修改,而不删除(在当前目录及其子目录上)。gitadd-u阶段修改和删除,无需新文件


详细信息:

git-add-A相当于git-add。;git-add-u。

关于gitadd的要点。它查看工作树,并将所有这些路径添加到已阶段的更改中,如果这些更改已更改或是新的且未被忽略,则不会阶段任何“rm”操作。

gitadd-u查看所有已跟踪的文件,如果这些文件不同或已被删除,则对这些文件进行更改。它不添加任何新文件,只对已跟踪的文件进行更改。

gitadd-A是实现这两个目的的便捷快捷方式。

您可以使用以下方式测试差异(注意,对于Git 2.x版本,您的Git-add.Git状态输出将不同):

git init
echo Change me > change-me
echo Delete me > delete-me
git add change-me delete-me
git commit -m initial

echo OK >> change-me
rm delete-me
echo Add me > add-me

git status
# Changed but not updated:
#   modified:   change-me
#   deleted:    delete-me
# Untracked files:
#   add-me

git add .
git status

# Changes to be committed:
#   new file:   add-me
#   modified:   change-me
# Changed but not updated:
#   deleted:    delete-me

git reset

git add -u
git status

# Changes to be committed:
#   modified:   change-me
#   deleted:    delete-me
# Untracked files:
#   add-me

git reset

git add -A
git status

# Changes to be committed:
#   new file:   add-me
#   modified:   change-me
#   deleted:    delete-me

我希望这可以增加一些清晰度。

!The syntax is
git add <limiters> <pathspec>
! Aka
git add (nil/-u/-A) (nil/./pathspec)

限制器可以是-u或-A或nil。

路径规范可以是文件路径或点“”以指示当前目录。

有关Git如何“添加”的重要背景知识:

Git永远不会自动识别不可见的文件(以点为前缀的文件)。它们甚至从未被列为“未追踪”。Git从不添加空文件夹。它们甚至从未被列为“未追踪”。(解决方法是向跟踪的文件中添加一个可能不可见的空白文件。)Git状态不会显示子文件夹信息,即未跟踪的文件,除非跟踪该子文件夹中的至少一个文件。在此之前,Git认为整个文件夹超出了范围,是一个“空的”。它没有跟踪的项目。指定filespec='.'(dot)或当前目录不是递归的,除非同时指定了-A。Dot严格指的是当前目录-它省略了上面和下面的路径。

现在,有了这些知识,我们可以应用上面的答案。

限制器如下。

-u=--update=跟踪文件的子集=>Add=否;更改=是;删除=是。=>如果项目被跟踪。-A=--all(没有这样的-A,这会导致语法错误)=所有未跟踪/跟踪文件的超集,除非在2.0之前的Git中,其中如果给定了点文件规范,则只考虑该特定文件夹。=>如果项目被识别,gitadd-A将找到并添加它。

路径规范如下。

在2.0之前的Git中,对于两个限制器(update和all),新的默认值是对整个工作树进行操作,而不是当前路径(Git1.9或更早版本),然而,在v2.0中,操作可以限制为当前路径:只需添加显式的点后缀(在Git1.9或更早版本中也有效);

git add-A。

git add-u。

总之,我的政策是:

确保所有要添加的块/文件都以git状态进行说明。如果由于文件/文件夹不可见而缺少任何项目,请单独添加它们。拥有一个好的.gitignore文件,这样通常只有感兴趣的文件才能被跟踪和/或识别。从存储库的顶层,“gitadd-A”添加所有项目。这适用于所有版本的Git。如果需要,从索引中删除任何所需项目。如果存在大错误,请执行“gitreset”以完全清除索引。