Git基础(四)
本节将给出几个重构项目时常用的Git命令。
一、删除不再追踪的内容
当我们需要在项目中删除某个文件,你可以手动删除并将修改再添加到暂存区。 看一个例子,首先在项目中创建一个文件并提交。
➜ git_test git:(master) touch test_rm.md
➜ git_test git:(master) ✗ git add test_rm.md
➜ git_test git:(master) ✗ git commit -m "first commit"
[master (root-commit) cab6745] first commit
1 file changed, 0 insertions(+), 0 deletions(-)
create mode 100644 test_rm.md
➜ git_test git:(master) git status
On branch master
nothing to commit, working tree clean
➜ git_test git:(master) ls
test_rm.md然后我们使用rm命令删除,再看看当前项目的状态:
➜ git_test git:(master) rm test_rm.md
➜ git_test git:(master) ✗ git status
On branch master
Changes not staged for commit:
(use "git add/rm <file>..." to update what will be committed)
(use "git restore <file>..." to discard changes in working directory)
deleted: test_rm.md
no changes added to commit (use "git add" and/or "git commit -a")可以看到,当rm命令执行后,修改发生在工作区,此时你还可以使用git restore <file>来将工作区的修改恢复。接下来我们使用git rm <file>,然后再来看看效果。
可以看到,让我们使用git rm之后,修改被直接添加到了暂存区。实际上,git rm就相当于:
二、挪动文件的位置或者为文件重命名
当需要挪动文件位置或者重命名某个文件时,你可以使用mv命令手动移动后再将修改添加到暂存区。
来看一个例子,我们将test_mv.md挪到test文件夹下。
修改被添加到了工作区,还需要手动将修改添加到暂存区,这和前面的rm类似。接下来使用git mv命令,再看看效果,先把之前的修改恢复吧。
可以看到,尽管test_mv.md已经被恢复到了原目录下,但是这时我们仍在存在Untracked的test文件夹,看看里面的内容。
被mv进来的文件还在!看来git并没有为我们执行类似于un-mv的操作,这很好理解,因为前面执行mv之后,使用git status查看的结果是显示test_mv.md文件被删除了。原因是test_mv.md被重命名为test/test_mv.md,git直追踪了test_mv.md而并没有追踪test/test_mv.md,所以git经过推断,得出该文件已经被删除的结论。
如果使用git mv,效果是什么呢?
可以看到,git直接将修改添加到了暂存区,而且推断出这是一次重命名。实际上,该命令就相当于:
三、总结
当需要重命名或者删除一些文件时,使用git rm和git mv可以减少我们的操作次数。
Last updated
Was this helpful?