git-add[-all|-A]和git-add.之间有什么区别。?
当前回答
一个更精炼的快速答案:
两者都在下面(与git add--all相同)
git add -A
暂存新的+修改的文件
git add .
阶段已修改+已删除文件
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
一个更精炼的快速答案:
两者都在下面(与git add--all相同)
git add -A
暂存新的+修改的文件
git add .
阶段已修改+已删除文件
git add -u
我讨厌git的分段机制,这在其他SCM工具中找不到。所以我总是使用:
\gitadd--all&&\gitcommit--all
(即使使用\git add--all,\git commit也足够了)
用于添加:
--no-ignore-removal --all | add, modify, and remove index entries to match the working tree
--ignore-removal --no-all | add, modify index entries to match the working tree
--intent-to-add | add an entry for the path to the index, with no content
-A是--all的缩写
gitadd<pathspec>等于:
对于Git 2.35.1版本:Git add--all<pathspec>Git:Git-add的旧版本--无所有<pathspec>
但是gitadd后面跟nothing,不等于gitadd--all,并且不会做任何事情:
gitadd--all(省略<pathspec>):处理整个工作树中的所有文件(旧版本的git用于将更新限制到当前目录及其子目录)。
gitcommit--全部
告诉命令自动暂存已修改和删除的文件,。你没有告诉Git的新文件不会受到影响
在Git2.0中,gitadd-A是默认值:gitadd。等于git add-A。。
gitadd<path>现在与“gitadd-A<path>”相同,因此“git-add-dir/”将注意到您从目录中删除的路径记录移除情况。在旧版本的Git中,“gitadd<path>”忽略了删除。您可以对如果确实需要,请在<path>中只添加添加或修改的路径。
gitadd-A类似于gitadd:/(从顶部git repo文件夹添加所有内容)。注意,git2.7(2015年11月)将允许您添加名为“:”的文件夹!参见Junio C Hamano(gitster)的承诺29abb33(2015年10月25日)。
注意,在谈论gitadd时,从git2.0开始(2014年第一季度或第二季度)。(工作树中的当前路径),必须使用“.”在其他gitadd命令中也是如此。
这意味着:
“git-add-A.”等同于“git-add.;git-add-u”
(注意git-add-A和git-add-u的额外“.”)
因为git add-A或git add-u将在整个工作树上运行(仅启动git 2.0),而不仅仅是在当前路径上运行。
这些命令将在Git2.0中的整个树上运行,以与“gitcommit-a”和其他命令保持一致。由于没有机制使“git-add-u”的行为类似于“git-add-u”,所以对于那些习惯于“git add-u”(没有路径规范)只更新当前子目录中路径的索引的人来说,在git 2.0到来之前开始训练他们的手指明确说出“git add-u”是很重要的。当这些命令在没有路径规范的情况下运行时,以及当您在当前目录之外进行本地更改时,会发出警告,因为Git2.0中的行为会有所不同从今天的版本来看,在这种情况下。
Git 2.0改变了一切(2014-05-28):
-A现在是默认值旧的行为现在可以使用--ignore删除。命令行上没有路径的子目录中的gitadd-u和gitadd-A对整个树进行操作。
因此,对于Git 2,答案是:
git添加。和git-add-A。在当前目录中添加新的/修改的/删除的文件gitadd—忽略删除。在当前目录中添加新的/修改的文件git add-u。在当前目录中添加修改/删除的文件如果没有圆点,则添加项目中的所有文件,而不考虑当前目录。
推荐文章
- Visual Studio代码如何解决合并冲突与git?
- 无法推送到远程分支,无法解析到分支
- Git:如何将数据库重置为特定的提交?
- 如何在合并期间使用Git和命令行保存本地文件或远程文件?
- 能够用一个命令推到所有git遥控器?
- 重新基于Git合并提交
- 忽略已经签入目录的内容?
- 如何从windows cmd保存git提交消息?
- (Mac) -bash: __git_ps1:命令未找到
- 如何删除多个已删除的文件在Git仓库
- 使用vimdiff查看所有' git diff '
- 如何拉特定的目录与git
- 本地存储库中的文件与源文件之间的差异
- 将Git存储库内容移动到另一个存储库,保存历史记录
- 如何在GitHub上创建自己的存储库?