git 常用的几剂后悔药

2024-04-16 10:32
文章标签 常用 git 后悔药 几剂

本文主要是介绍git 常用的几剂后悔药,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在 git add 之前,放弃对文件的所有修改

就算你用 rm 删除了也无所谓,照样还原回来。(如果是没有用 git 进行跟踪的文件,可不要轻易这么尝试哟!)

git checkout --

当你对一个文件进行了修改,还没有 add 进暂存区,你想要放弃所有的修改,将文件恢复到没有修改之前的样子,这时候可以使用 git checkout -- ,这条命令会将文件恢复到上一次 commit 的时候这个文件的样子。

[root@master GitTest]# vim hello.txt 
[root@master GitTest]# git status
On branch master
Your branch is up to date with 'origin/master'.Changes not staged for commit:(use "git add <file>..." to update what will be committed)(use "git restore <file>..." to discard changes in working directory)modified:   hello.txtno changes added to commit (use "git add" and/or "git commit -a")
[root@master GitTest]# git checkout -- hello.txt 
[root@master GitTest]# git status
On branch master
Your branch is up to date with 'origin/master'.nothing to commit, working tree clean

git restore  (推荐使用)

貌似新版本的 git restore  和 git checkout -- 差不多,以后可能用 git restore 更多一些了,毕竟见文知意,而且命令还短。

[root@master GitTest]# vim hello.txt 
[root@master GitTest]# git status
On branch master
Your branch is up to date with 'origin/master'.Changes not staged for commit:(use "git add <file>..." to update what will be committed)(use "git restore <file>..." to discard changes in working directory)modified:   hello.txtno changes added to commit (use "git add" and/or "git commit -a")
[root@master GitTest]# git restore hello.txt
[root@master GitTest]# git status
On branch master
Your branch is up to date with 'origin/master'.nothing to commit, working tree clean

将 git add 的文件变成 git add 之前的状态

git restore --staged <file>

[looking@master GitTest]$ vim b.txt
[looking@master GitTest]$ git add b.txt
[looking@master GitTest]$ git status
On branch master
Your branch is up to date with 'origin/master'.Changes to be committed:(use "git restore --staged <file>..." to unstage)modified:   b.txt[looking@master GitTest]$ git restore --staged b.txt
[looking@master GitTest]$ git status
On branch master
Your branch is up to date with 'origin/master'.Changes not staged for commit:(use "git add <file>..." to update what will be committed)(use "git restore <file>..." to discard changes in working directory)modified:   b.txtno changes added to commit (use "git add" and/or "git commit -a")

git reset HEAD <file>

Administrator@PC-20200713AJJH MINGW64 /d/MyProject/Python/GitTest (master)
$ vi myGit.txt # 添加新行 hello worldAdministrator@PC-20200713AJJH MINGW64 /d/MyProject/Python/GitTest (master)
$ git add myGit.txtAdministrator@PC-20200713AJJH MINGW64 /d/MyProject/Python/GitTest (master)
$ git status
On branch master
Your branch is ahead of 'origin/master' by 2 commits.(use "git push" to publish your local commits)Changes to be committed:(use "git reset HEAD <file>..." to unstage)modified:   myGit.txtAdministrator@PC-20200713AJJH MINGW64 /d/MyProject/Python/GitTest (master)
$ git reset HEAD myGit.txt
Unstaged changes after reset:
M       myGit.txtAdministrator@PC-20200713AJJH MINGW64 /d/MyProject/Python/GitTest (master)
$ git status
On branch master
Your branch is ahead of 'origin/master' by 2 commits.(use "git push" to publish your local commits)Changes not staged for commit:(use "git add <file>..." to update what will be committed)(use "git checkout -- <file>..." to discard changes in working directory)modified:   myGit.txtno changes added to commit (use "git add" and/or "git commit -a")

将最近 commit 中的某个文件重新修改提交

git restore -s HEAD~1 <file>

执行以后,git commit 的 log 信息并没有丢失,对 file 的修改会 rollback 回滚,你可以重新修改文件,然后 git add , git commit 对文件的修改重新进行提交。(适用场景:最近的 commit 修改了多个文件,但是想对其中一个文件的提交撤销并重新修改)

[looking@master GitTest]$ git status
On branch master
Your branch is ahead of 'origin/master' by 1 commit.(use "git push" to publish your local commits)nothing to commit, working tree clean
[looking@master GitTest]$ git restore -s HEAD~1 hello.txt
[looking@master GitTest]$ git status
On branch master
Your branch is ahead of 'origin/master' by 1 commit.(use "git push" to publish your local commits)Changes not staged for commit:(use "git add <file>..." to update what will be committed)(use "git restore <file>..." to discard changes in working directory)modified:   hello.txtno changes added to commit (use "git add" and/or "git commit -a")

重新填写 git commit 信息

git commit --amend

有时候我们发现提交信息填写错了,或者在提交完成之后才发现有几个文件没有提交,这时候可以使用 git commit --amend 尝试重新进行提交。

$ git commit --amend- mv test.txt to test directory
+ mv test.txt to test dir# Please enter the commit message for your changes. Lines starting
# with '#' will be ignored, and an empty message aborts the commit.
#
# Date:      Wed Jul 29 22:28:31 2020 +0800
#
# On branch master
# Your branch is ahead of 'origin/master' by 2 commits.
#   (use "git push" to publish your local commits)
#
# Changes to be committed:
#       renamed:    test.txt -> test/test.txt
#$ git commit --amend
[master db41223] mv test.txt to test dirDate: Wed Jul 29 22:28:31 2020 +08001 file changed, 1 insertion(+)rename test.txt => test/test.txt (71%)

不想让 git 继续跟踪某个文件

git rm --cached

如果你只是想从暂存区删除文件,但是工作区的文件保持不变(将文件保存在磁盘),也就是说将文件保存在磁盘但是不想让 Git 进行跟踪,使用如下命令即可 git rm --cached :

Administrator@PC-20200713AJJH MINGW64 /d/MyProject/Python/GitTest (master)
$ vi test.txt  # 新行添加 hello world
git
Administrator@PC-20200713AJJH MINGW64 /d/MyProject/Python/GitTest (master)
$ git status
On branch master
Your branch is ahead of 'origin/master' by 1 commit.(use "git push" to publish your local commits)Changes not staged for commit:(use "git add <file>..." to update what will be committed)(use "git checkout -- <file>..." to discard changes in working directory)modified:   test.txtno changes added to commit (use "git add" and/or "git commit -a")Administrator@PC-20200713AJJH MINGW64 /d/MyProject/Python/GitTest (master)
$ git rm --cached test.txt
rm 'test.txt'Administrator@PC-20200713AJJH MINGW64 /d/MyProject/Python/GitTest (master)
$ git status  # 显示文件 test.txt 为 Untracked files
On branch master
Your branch is ahead of 'origin/master' by 1 commit.(use "git push" to publish your local commits)Changes to be committed:(use "git reset HEAD <file>..." to unstage)deleted:    test.txtUntracked files:(use "git add <file>..." to include in what will be committed)test.txt

将 git 仓库变成普通目录

rm -rf .git

这个要稍微简单一些了,毕竟 git 能进行版本控制最主要的就是因为这个隐藏的 .git 目录了,删了就可以了(请谨慎操作)。

[root@master GitTest]# git status
On branch master
Your branch is up to date with 'origin/master'.nothing to commit, working tree clean
[root@master GitTest]# rm -rf .git
[root@master GitTest]# git status
fatal: not a git repository (or any of the parent directories): .git

撤销最近的 commit,但是不撤销对应 commit 所做的文件修改

git reset HEAD~1

注:使用此命令,你原来提交的代码都在,不会被撤销,也即只会撤销  commit 记录(不对文件内容进行任何修改)。

[root@master GitTest]# git status
# On branch master
nothing to commit, working directory clean
[root@master GitTest]# vim b.txt # 删除了文件最后一行# 下面 commit 失败,因为修改的文件还没添加到暂存区
[root@master GitTest]# git commit -m "delete last line in b.txt"
# On branch master
# Changes not staged for commit:
#   (use "git add <file>..." to update what will be committed)
#   (use "git checkout -- <file>..." to discard changes in working directory)
#
#	modified:   b.txt
#
no changes added to commit (use "git add" and/or "git commit -a")------------------------------------------------------------
[root@master GitTest]# git add b.txt
[root@master GitTest]# git commit -m "delete last line in b.txt"
[master 131c2e9] delete last line in b.txt1 file changed, 1 deletion(-)
[root@master GitTest]# git log
commit 131c2e9e676726168a87db678c17e8ec404b8c4e
Author: looking <looking@qq.com>
Date:   Sat Aug 8 01:35:09 2020 +0800delete last line in b.txtcommit f3b4d4abd65a59c8a03df6caccf28f33422b4614
Author: looking <looking@qq.com>
Date:   Tue Aug 4 21:42:27 2020 +0800This is a combination of 2 commits.add hello in new line of looking.txtadd world in new line of looking.txt------------------------------------------------------------
# 注意啦,放大招啦。
[root@master GitTest]# git reset HEAD~
Unstaged changes after reset:
M	b.txt
# 这个时候回到了 add 和 commit 提交之前,但是在文件 b.txt 修改之后的那个状态[root@master GitTest]# git status
# On branch master
# Changes not staged for commit:
#   (use "git add <file>..." to update what will be committed)
#   (use "git checkout -- <file>..." to discard changes in working directory)
#
#	modified:   b.txt
#
no changes added to commit (use "git add" and/or "git commit -a")------------------------------------------------------------
# 因为 commit 被撤销了,所以我们再重新提交一次
[root@master GitTest]# git add b.txt
[root@master GitTest]# git commit -m "delete last line in b.txt"
[master 33796e9] delete last line in b.txt1 file changed, 1 deletion(-)
[root@master GitTest]# git log
commit 33796e9844af4b6e1ee23c2d98ec5be4c5fef3e6
Author: looking <looking@qq.com>
Date:   Sat Aug 8 01:44:27 2020 +0800delete last line in b.txtcommit f3b4d4abd65a59c8a03df6caccf28f33422b4614
Author: looking <looking@qq.com>
Date:   Tue Aug 4 21:42:27 2020 +0800This is a combination of 2 commits.add hello in new line of looking.txtadd world in new line of looking.txtcommit cd3e33625578c3aaf6f19b69c878559a1dcf552a
Merge: 640fd3c 3fceb8a
[root@master GitTest]# 

撤销最近的 commit,同时撤销对应 commit 所作的文件修改

git reset --hard HEAD^1

注:使用之后,你最新的 commit 命令下修改的内容将完全被撤销,最近一次的 commit 记录也没了。

[root@master GitTest]# git add b.txt
[root@master GitTest]# git commit -m "modify file b.txt"
[master be7abc1] modify file b.txt1 file changed, 2 deletions(-)
[root@master GitTest]# git log
commit be7abc12a1a94e9390bd6c7f4bc747f9bbe86ab9
Author: looking <looking@qq.com>
Date:   Sat Aug 8 02:01:32 2020 +0800modify file b.txtcommit f3b4d4abd65a59c8a03df6caccf28f33422b4614
Author: looking <looking@qq.com>
Date:   Tue Aug 4 21:42:27 2020 +0800This is a combination of 2 commits.add hello in new line of looking.txtadd world in new line of looking.txt
------------------------------------------------------------  
[root@master GitTest]# cat b.txt 
hahahahaha
hohohohoho
rebase test
add one line in b.txt by user B
add one line in b.txt by user B again
------------------------------------------------------------  
[root@master GitTest]# git reset --hard HEAD^1
HEAD is now at f3b4d4a This is a combination of 2 commits.
------------------------------------------------------------  
# 注意看,git reset --hard HEAD^1 执行前后, b.txt 文件内容发生变化了哟!
#  git log 的最近一次 commit 没有了!
------------------------------------------------------------
[root@master GitTest]# cat b.txt 
hahahahaha
hohohohoho
hehehehehe
rebase test
add one line in b.txt by user B
add one line in b.txt by user B again
hello world
------------------------------------------------------------  
[root@master GitTest]# git log
commit f3b4d4abd65a59c8a03df6caccf28f33422b4614
Author: looking <looking@qq.com>
Date:   Tue Aug 4 21:42:27 2020 +0800This is a combination of 2 commits.add hello in new line of looking.txtadd world in new line of looking.txt

回滚之前某个 commit 提交的内容

git revert <commit-id>

git revert 是用于“反做”某一个版本,以达到撤销该版本的修改的目的。 git reset 的作用是修改HEAD的位置,且那个版本之后提交的版本都会丢失。

git revert 可以回滚某个 commit 对应的修改,所以在这点上面 revert 和 reset 是不一样的。

root@master ~/GitTest# vim hello.txt 
root@master ~/GitTest# git add hello.txt 
root@master ~/GitTest# git commit -m "add hello in hello.txt"root@master ~/GitTest# git show
commit 72bfd90b8194b1d3537fc62a22d6776d32ae5b4b (HEAD -> master)
Author: looking <looking@qq.com>
Date:   Mon Jun 6 17:11:10 2022 +0800add hello in hello.txtdiff --git a/hello.txt b/hello.txt
index 83585f1..25f7272 100644
--- a/hello.txt
+++ b/hello.txt
@@ -1,3 +1,4 @@
+hellonicehello worldhello world. I am Looking

revert 是新建一个 commit 来回滚之前 commit-id 的操作,可以看到 git revert <commit-id> 执行的操作是 commit-id 操作的逆操作,也就是 commit-id 做的动作,它都会反向操作一遍。

root@master ~/GitTest# git revert 72bfd90b8194b1d3537fc62a22d6776d32ae5b4b
[master 780b3e0] Revert "add hello in hello.txt"1 file changed, 1 deletion(-)
root@master ~/GitTest# git show
commit 780b3e0044b10aa62a6459a44d4b657da76a501d (HEAD -> master)
Author: looking <looking@qq.com>
Date:   Mon Jun 6 17:26:12 2022 +0800Revert "add hello in hello.txt"This reverts commit 72bfd90b8194b1d3537fc62a22d6776d32ae5b4b.diff --git a/hello.txt b/hello.txt
index 25f7272..83585f1 100644
--- a/hello.txt
+++ b/hello.txt
@@ -1,4 +1,3 @@
-hellonicehello worldhello world. I am Looking

 reset 的话,则 reset 对应 commit-id 之后的修改就丢失了(这也是 reset 比 revert 更危险的原因之一)。

root@master ~/GitTest# git reset --hard 1912baa1b9457add393f48c41ffd35957aa8b569
HEAD is now at 1912baa deal merge conflict in hello.txt

当然,回滚也是可能会造成冲突的,稍微注意一下就行。比如有人在你之前 commit-id 修改的地方又重新做了新的修改,你 revert 这个 commit-id 的话肯定就不可避免要 conflict 了。 

修改倒数二个 commit 相关内容

git rebase -i HEAD~2 和 git rebase --continue。git 修改倒数二个 commit_TomorrowAndTuture的博客-CSDN博客

git rebase -i HEAD~2

git rebase -i HEAD~2 以后,git 会自动给你切换到下面这个界面,你将你需要修改的那个 commit 前边的 pick 修改为 edit。

[root@master GitTest]# git rebase -i HEAD~2edit 3d87922 nice to meet you
pick df5f952 nice to meet you too# Rebase 3f20612..df5f952 onto 3f20612 (2 commands)
#
# Commands:
# p, pick <commit> = use commit
# r, reword <commit> = use commit, but edit the commit message
# e, edit <commit> = use commit, but stop for amending
# s, squash <commit> = use commit, but meld into previous commit
# f, fixup <commit> = like "squash", but discard this commit's log message
# x, exec <command> = run command (the rest of the line) using shell
# b, break = stop here (continue rebase later with 'git rebase --continue')
# d, drop <commit> = remove commit
# l, label <label> = label current HEAD with a name
# t, reset <label> = reset HEAD to a label
# m, merge [-C <commit> | -c <commit>] <label> [# <oneline>]
# .       create a merge commit using the original merge commit's
# .       message (or the oneline, if no original merge commit was
# .       specified). Use -c <commit> to reword the commit message.

然后保存退出,而且 git 也已经提醒你版本已经 stopped 在这个 commit 节点了,你可以开始你的表演(修改)了:

[root@master GitTest]# git rebase -i HEAD~2
Stopped at 3d87922...  nice to meet you
You can amend the commit now, withgit commit --amend Once you are satisfied with your changes, rungit rebase --continue

假如我想把原来插入的 nice to meet you 修改为 nice。用 vim 修改后用 git commit --amend(不会产生新的 commit 提交) 重新提交 commit。

[root@master GitTest]# vim hello.txt
[root@master GitTest]# git add hello.txt 
[root@master GitTest]# git commit --amendnice # Please enter the commit message for your changes. Lines starting
# with '#' will be ignored, and an empty message aborts the commit.
#
# Date:      Mon Aug 31 21:16:51 2020 +0800
#
# interactive rebase in progress; onto 3f20612[detached HEAD bcbfd91] niceDate: Mon Aug 31 21:16:51 2020 +08001 file changed, 1 insertion(+)

git rebase --continue

然后继续 git rebase --continue 就好了(如果没有冲突,直接 git rebase --continue 也是极好的)。

[root@master GitTest]# git add hello.txt 
[root@master GitTest]# git rebase --continue
[detached HEAD 72017cd] nice to meet you too1 file changed, 1 insertion(+)
Successfully rebased and updated refs/heads/master.

git rebase --abort

这个是你在 git rebase 过程当中的后悔药,如果你在 rebase 的任何过程中想退出 rebase 过程,直接执行 git rebase --abort 就直接退出回到 rebase 之前的状态啦。

将最近多个commit合并成一个(以最近两个为例)

git rebase -i HEAD~2 (下面列表中,越靠下的 commit 离 HEAD 越近)

pick b6fdaf6 add nice in hello.txt
squash 63bb8ef add hello world in world.txt# Rebase eced426..63bb8ef onto eced426 (2 commands)
#
# Commands:
# p, pick <commit> = use commit
# r, reword <commit> = use commit, but edit the commit message
# e, edit <commit> = use commit, but stop for amending
# s, squash <commit> = use commit, but meld into previous commit
# f, fixup <commit> = like "squash", but discard this commit's log message
# x, exec <command> = run command (the rest of the line) using shell
# b, break = stop here (continue rebase later with 'git rebase --continue')
# d, drop <commit> = remove commit
# l, label <label> = label current HEAD with a name
# t, reset <label> = reset HEAD to a label
# m, merge [-C <commit> | -c <commit>] <label> [# <oneline>]
# .       create a merge commit using the original merge commit's
# .       message (or the oneline, if no original merge commit was
# .       specified). Use -c <commit> to reword the commit message.
#
# These lines can be re-ordered; they are executed from top to bottom.
#
# If you remove a line here THAT COMMIT WILL BE LOST.
#
# However, if you remove everything, the rebase will be aborted.

使用 squash 将最近一个提交 squash 合并到上一个提交(也就是倒数第二个 commit)产生新的 commit,然后:wq 保存。

然后继续编辑提交详情信息,保存退出即可。

# This is a combination of 2 commits.
# This is the 1st commit message:add nice in hello.txt# This is the commit message #2:add hello world in world.txt
commit bf00e63e180caa680584920c08f396818c2fcf02 (HEAD -> master)
Author: looking <looking@qq.com>
Date:   Tue Dec 22 09:51:15 2020 +0800add nice in hello.txt and add hello world in world.txtcommit eced426098acd286cb45cb7191f83ddee9cc228c
Author: Looking <38554375+2392863668@users.noreply.github.com>
Date:   Tue Dec 22 10:25:57 2020 +0800clear hello.txt

将多个不连续commit合并成一个

git rebase -i HEAD~6(下面列表中,越靠下的 commit 离 HEAD 越近)

这个和上面的操作类似,还是使用 git rebase 命令

root@master ~/GitTest# git rebase -i HEAD~6
pick b6fdaf6 add nice in hello.txt
pick 63bb8ef add hello world in world.txt
pick ba8b2b1 delete world in first line of hello.txt
pick 5983ee6 modify b.txt
pick 5eaae9c modify hello.txt
pick 5c528bb modify c.txt

比如说我想将倒数第2个,第4个,第6个 commit (和操作 hello.txt 相关的几个不连续 commit)都合并到一个 commit,就这么调整顺序和操作如下:

pick 63bb8ef add hello world in world.txt
pick b68f98f modify b.txt
pick b6fdaf6 add nice in hello.txt
s ba8b2b1 delete world in first line of hello.txt
s 2820a56 modify hello.txt
pick 824c246 modify c.txt

 然后保存 commit 就好了(这块强调一下,针对有相互依赖关系的 commit 提交,千万不要轻易改变 commit 的相对顺序,否者可能会出现冲突——如果你不嫌麻烦要去处理冲突的忽略。比如我这块对 hello.txt 操作的三个 commit ,相对顺序并没有发生变化;虽然我其他 commit 和 这三个 commit 的相对顺序发生了变化,但是其他 commit 和这三个关联不大,不会出现冲突,所以也就没太大影响)

root@master ~/GitTest# git log
commit d6566c3000afe7a057d5b54946f828b3b9bcffa0 (HEAD -> master)
Author: looking <looking@qq.com>
Date:   Fri Feb 24 16:12:04 2023 +0800modify c.txtcommit a9f43a7acc4830b50df48d4a0187154fe3f644c0
Author: looking <looking@qq.com>
Date:   Tue Dec 22 09:51:15 2020 +0800add nice in hello.txtdelete world in first line of hello.txtmodify hello.txtcommit 6bc4f93f821b4946a725bf20c2fd6643e244a380
Author: looking <looking@qq.com>
Date:   Fri Feb 24 16:11:24 2023 +0800modify b.txtcommit c18dc0314ab997f061350f89d7f983bf5687a27a
Author: looking <looking@qq.com>
Date:   Tue Dec 22 09:54:39 2020 +0800add hello world in world.txt

将代码临时切换回之前的某个稳定版本(不乐意的话还可以切换回来)

git checkout  和 git checkout master。

[root@master GitTest]# git checkout 3f2061298d921378da14f4003753f1f277e67243
Note: switching to '3f2061298d921378da14f4003753f1f277e67243'.You are in 'detached HEAD' state. You can look around, make experimental
changes and commit them, and you can discard any commits you make in this
state without impacting any branches by switching back to a branch.If you want to create a new branch to retain commits you create, you may
do so (now or later) by using -c with the switch command. Example:git switch -c <new-branch-name>Or undo this operation with:git switch -Turn off this advice by setting config variable advice.detachedHead to falseHEAD is now at 3f20612 I am Looking
[root@master GitTest]# git checkout master
Previous HEAD position was 3f20612 I am Looking
Switched to branch 'master'
Your branch is up to date with 'origin/master'.

将代码永久切换回之前的某个稳定版本(对应分支的指针也一同切换过去了)

git reset --hard commitId(谨慎使用)

如果想恢复到之前某个提交的版本,且那个版本之后提交的版本我们都不要了,就可以用这种方法(这个和 git checkout 最大的不同在于它把你的 master(分支指针所引用的 commit-id ——正常情况下指向当前分支的最新提交点) 也切换过去了,你要再想用 git checkout master 可就回不去 origin/master 了哟,如果你还记得 commitId 的话,还是可以切换回去的)。

master:本地主分支。origin/master:远端主分支。

[root@master GitTest]# git reset --hard 3f2061298d921378da14f4003753f1f277e67243
HEAD is now at 3f20612 I am Looking[root@master GitTest]# git checkout master
Already on 'master'
Your branch is behind 'origin/master' by 12 commits, and can be fast-forwarded.(use "git pull" to update your local branch)[root@master GitTest]# git reset --hard 1912baa1b9457add393f48c41ffd35957aa8b569
HEAD is now at 1912baa deal merge conflict in hello.txt
[root@master GitTest]# git checkout master
Already on 'master'
Your branch is up to date with 'origin/master'.

删除远端分支

git push origin --delete <branch-name>

快速保存和恢复临时工作现场

git stash 和 git stash pop

git stash 结合 git stash pop 适用于快速保存和和恢复临时工作现场(比如你在 branch1 正在安安心心写代码,突然老板让你赶紧去 branch2 去修一个紧急 bug,可以使用 git stash 将当前未提交的工作快速暂存到 git 堆栈,到 biranch2 修改 bug 以后再切换回 branch1,再次 git stash pop 快速恢复现场),还可以适用于快速对比程序修改前后的运行差异,而且可以在现有修改的基础上继续修改。 

丢弃本地所有未提交的修改

git stash 同时 git stash clear

针对本地所有修改了但是还没进行 git commit 提交的部分,即使已经使用了 git add,也仍然可以丢弃。

[root@master GitTest]# git status
On branch master
Your branch is ahead of 'origin/master' by 1 commit.(use "git push" to publish your local commits)Changes to be committed:(use "git restore --staged <file>..." to unstage)deleted:    b.txtmodified:   hello.txtChanges not staged for commit:(use "git add <file>..." to update what will be committed)(use "git restore <file>..." to discard changes in working directory)modified:   c.txt[root@master GitTest]# git stash
Saved working directory and index state WIP on master: 2017dee add newline in c.txt
[root@master GitTest]# git stash clear
[root@master GitTest]# git status
On branch master
Your branch is ahead of 'origin/master' by 1 commit.(use "git push" to publish your local commits)nothing to commit, working tree clean

丢弃本地所有修改,强制远端拉取覆盖本地

git fetch --all ; git reset --hard origin/master

如果你想以远程仓库的版本内容为准,丢弃本地所有修改(重置了暂存区的内容,而且还修改重置了本地工作区的内容,即使是已提交 commit 的部分也会重置),但是又不想删除本地仓库以后再次 git clone,那么就按下边这么做吧(这里的 origin/master 可以认为是一个指针,初次拉取仓库时,他指向了远端 origin 仓库 master 分支的最新提交点,只有当本地 commit 被 push 到远端仓库的时候,指针的指向才会发生改变)。

git fetch --all; git reset --hard origin/master
commit 44892cd7d4c8c36267f6af9f8568fb5369eaaddc (HEAD -> master)
Author: lukaiyi <lukaiyi@zdns.cn>
Date:   Fri Mar 10 15:42:49 2023 +0800testcommit 1912baa1b9457add393f48c41ffd35957aa8b569 (origin/master, origin/HEAD)
Merge: ba8b2b1 5f7be5d
Author: looking <looking@qq.com>
Date:   Wed Dec 23 15:34:02 2020 +0800deal merge conflict in hello.txt
root@localhost ~/GitTest (master)# git push origin master
Username for 'https://gitee.com': 15249089066
Password for 'https://15249089066@gitee.com':
Enumerating objects: 5, done.
Counting objects: 100% (5/5), done.
Delta compression using up to 4 threads
Compressing objects: 100% (3/3), done.
Writing objects: 100% (3/3), 290 bytes | 290.00 KiB/s, done.
Total 3 (delta 2), reused 0 (delta 0), pack-reused 0
remote: Powered by GITEE.COM [GNK-6.4]
To https://gitee.com/L2392863668/GitTest.git1912baa..44892cd  master -> masterroot@localhost ~/GitTest (master)# git log
commit 44892cd7d4c8c36267f6af9f8568fb5369eaaddc (HEAD -> master, origin/master, origin/HEAD)
Author: lukaiyi <lukaiyi@zdns.cn>
Date:   Fri Mar 10 15:42:49 2023 +0800testcommit 1912baa1b9457add393f48c41ffd35957aa8b569
Merge: ba8b2b1 5f7be5d
Author: looking <looking@qq.com>
Date:   Wed Dec 23 15:34:02 2020 +0800deal merge conflict in hello.txt

git fetch --all ; git reset --hard HEAD

如果你只想重置当前分支未提交的内容(已提交的内容不被重置),那就直接用  HEAD 就可以了,像上面这样即可。

丢弃远端所有修改,强制推送覆盖远端 

git push -f <repo> <branch>

这个好像没啥多说的,只要你考虑好了,就强制推送就好了啦。默认是 git push -f origin master。

删除本地仓库,重新克隆(终极解决方案)

rm -rf GitTest

git clone https://github.com/2392863668/GitTest

如果你想以远程仓库的版本内容为准,丢弃本地所有修改(包括仓库里边 untracked file 文件的改动),那就重新克隆一个吧。

[root@master workspace]# rm -rf GitTest
[root@master workspace]# git clone https://github.com/2392863668/GitTest
Cloning into 'GitTest'...
remote: Enumerating objects: 26, done.
remote: Counting objects: 100% (26/26), done.
remote: Compressing objects: 100% (19/19), done.
remote: Total 247 (delta 11), reused 15 (delta 5), pack-reused 221
Receiving objects: 100% (247/247), 1.27 MiB | 869.00 KiB/s, done.
Resolving deltas: 100% (95/95), done.

重要知识点总结

  1. “^”代表父提交,当一个提交有多个父提交时,可以通过在”^”后面跟上一个数字,表示第几个父提交,”^”相当于”^1”.

  2. ~<n>相当于连续的<n>个”^”.

  3. checkout只会移动HEAD指针,reset会改变HEAD的引用值。

  4. HEAD、<branch>、origin/<branch> 都属于指针,HEAD 一般指向当前位置最新提交点,<branch> 一般指向对应分支的最新提交点、origin/<branch> 一般指向对应分支远端origin仓库的最新提交点,本地的 commit 提交,在 push 到远端之前,origin/<branch> 的引用指向一般不会发生变化。

  5. git commit -am "xxx" 和 git add . ; git commit -m "xxx" 操作其实不等价,-am 参数只会将已追踪的文件进行 add 和 commit,而先 git add . 会将未追踪的文件也添加到暂存区

这篇关于git 常用的几剂后悔药的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/908546

相关文章

C#中读取XML文件的四种常用方法

《C#中读取XML文件的四种常用方法》Xml是Internet环境中跨平台的,依赖于内容的技术,是当前处理结构化文档信息的有力工具,下面我们就来看看C#中读取XML文件的方法都有哪些吧... 目录XML简介格式C#读取XML文件方法使用XmlDocument使用XmlTextReader/XmlTextWr

CSS弹性布局常用设置方式

《CSS弹性布局常用设置方式》文章总结了CSS布局与样式的常用属性和技巧,包括视口单位、弹性盒子布局、浮动元素、背景和边框样式、文本和阴影效果、溢出隐藏、定位以及背景渐变等,通过这些技巧,可以实现复杂... 一、单位元素vm 1vm 为视口的1%vh 视口高的1%vmin 参照长边vmax 参照长边re

Python中操作Redis的常用方法小结

《Python中操作Redis的常用方法小结》这篇文章主要为大家详细介绍了Python中操作Redis的常用方法,文中的示例代码简洁易懂,具有一定的借鉴价值,有需要的小伙伴可以了解一下... 目录安装Redis开启、关闭Redisredis数据结构redis-cli操作安装redis-py数据库连接和释放增

Git提交代码详细流程及问题总结

《Git提交代码详细流程及问题总结》:本文主要介绍Git的三大分区,分别是工作区、暂存区和版本库,并详细描述了提交、推送、拉取代码和合并分支的流程,文中通过代码介绍的非常详解,需要的朋友可以参考下... 目录1.git 三大分区2.Git提交、推送、拉取代码、合并分支详细流程3.问题总结4.git push

一文详解Python中数据清洗与处理的常用方法

《一文详解Python中数据清洗与处理的常用方法》在数据处理与分析过程中,缺失值、重复值、异常值等问题是常见的挑战,本文总结了多种数据清洗与处理方法,文中的示例代码简洁易懂,有需要的小伙伴可以参考下... 目录缺失值处理重复值处理异常值处理数据类型转换文本清洗数据分组统计数据分箱数据标准化在数据处理与分析过

Java中Object类的常用方法小结

《Java中Object类的常用方法小结》JavaObject类是所有类的父类,位于java.lang包中,本文为大家整理了一些Object类的常用方法,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. public boolean equals(Object obj)2. public int ha

Git中恢复已删除分支的几种方法

《Git中恢复已删除分支的几种方法》:本文主要介绍在Git中恢复已删除分支的几种方法,包括查找提交记录、恢复分支、推送恢复的分支等步骤,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录1. 恢复本地删除的分支场景方法2. 恢复远程删除的分支场景方法3. 恢复未推送的本地删除分支场景方法4. 恢复

Java 字符数组转字符串的常用方法

《Java字符数组转字符串的常用方法》文章总结了在Java中将字符数组转换为字符串的几种常用方法,包括使用String构造函数、String.valueOf()方法、StringBuilder以及A... 目录1. 使用String构造函数1.1 基本转换方法1.2 注意事项2. 使用String.valu

VUE动态绑定class类的三种常用方式及适用场景详解

《VUE动态绑定class类的三种常用方式及适用场景详解》文章介绍了在实际开发中动态绑定class的三种常见情况及其解决方案,包括根据不同的返回值渲染不同的class样式、给模块添加基础样式以及根据设... 目录前言1.动态选择class样式(对象添加:情景一)2.动态添加一个class样式(字符串添加:情

Java 枚举的常用技巧汇总

《Java枚举的常用技巧汇总》在Java中,枚举类型是一种特殊的数据类型,允许定义一组固定的常量,默认情况下,toString方法返回枚举常量的名称,本文提供了一个完整的代码示例,展示了如何在Jav... 目录一、枚举的基本概念1. 什么是枚举?2. 基本枚举示例3. 枚举的优势二、枚举的高级用法1. 枚举