121、git

本文介绍了Git的提交、合并及回滚操作,包括如何使用gitadd、gitcommit、gitpush将文件提交到远程仓库,以及如何通过gitreset--hard回滚到特定提交。此外,还讲解了gitrevert用于重做某次提交的内容,并通过实例演示了这两个命令的使用。强调在团队协作中谨慎使用gitreset,避免丢失代码。
摘要由CSDN通过智能技术生成

(1)提交文件到远程仓库: 

  1. git add 文件名 : 将工作文件修改提交到本地暂存区,这个时候还不算添加到了本地仓库。例如:git add test.c ;
  2. git commit -m 描述信息: 把缓存区里的文件提交到本地仓库。例如:git commit -m "添加文件";
  3. git push origin master : 将本地仓库内容推到远程仓库

(2)合并提交: 

  1.  先使用git log查看历史版本;
  2. 再使用git reset --soft 版本号 命令回滚,回滚到被commited的状态;
  3. git push -f 强行提交到远程仓库;
  • 工作区:工作区就是你当前的工作目录
  • 缓存区:这里存放了你使用git add命令提交的文件描述信息,它位于.git目录下的index文件中

开发过程中,我们都有自己的特性分支,所以冲突发生的并不多。我和别人同时修改同一个文件,他提交后我再提交就会报冲突的错误。

(3)git reset 和 git reverse的区别: 

  • HEAD 是指向当前分支的最新提交的指针,可以在任意分支进行切换;
  • master分支,是一个 git 代码仓库的主分支也是默认分支;
  • commit 每一次提交代码都会产生一个 commit id 来标识工作区的变更与改动。

git reset 的作用是将 HEAD 指向指定的版本上去:

1 使用 git log 查看提交记录:

commit b0ef8f9125226af8f06ff1aba7c1f1fc83adea9b (HEAD -> master, origin/master)
Author: debuginn <debuginn@icloud.com>
Date:   Tue Sep 21 16:36:39 2021 +0800

    feat add 3.go

commit 338bf3e30983d34074f37a18b3ff80ea9bca75f0
Author: debuginn <debuginn@icloud.com>
Date:   Tue Sep 21 16:36:09 2021 +0800

    feat add 2.go

commit 6b166ed34962da08d944e2b1d3f36d9015dd8f35
Author: debuginn <debuginn@icloud.com>
Date:   Tue Sep 21 16:35:16 2021 +0800

    feat add 1.go

这里可以看到我们提交了三次记录,我们现在想恢复到第一次 commit 提交的时候。

2 使用 git reset --hard 命令操作:

➜  demo git:(master) git reset --hard 6b166ed34962da08d944e2b1d3f36d9015dd8f35
HEAD 现在位于 6b166ed feat add 1.go

再次查看 git log :

commit 6b166ed34962da08d944e2b1d3f36d9015dd8f35 (HEAD -> master)
Author: debuginn <debuginn@icloud.com>
Date:   Tue Sep 21 16:35:16 2021 +0800

    feat add 1.go

此时我们可以看到已经恢复到了第一次提交代码的时候,目前我们是使用 git reset --hard 的方式,其实这里存在着三种方式,TODO 下一篇 git 操作讲一下。

这时候我们只是讲本地的 HEAD 指向了 main 分支的 commit 1,但是远程并没有变更,此时需要强行推一下就可以了。

3 使用git push -f 强行推送到远程:

➜  demo git:(master) git push -f
总共 0(差异 0),复用 0(差异 0),包复用 0
To github.com:debuginn/demo.git
 + b98f95e...6b166ed master -> master (forced update)

此时我们可以看到远程也没有了我们之前提交的三次记录而是只有第一次的提交记录。

warning 警告
在团队合作的共同操作一个仓库的时候, git reset 命令一定要慎重使用,在使用的时候一定要再三确认其他同学的代码是否会被重置操作而导致代码丢失,导致一些提交记录的丢失,这些都是不可逆的,一定要慎重。

Git revert

git revert是用来重做某一个 commit 提交的内容,在我们原始的提交之中,我们会发现分支上面有创建了一个新的 commit 提交,而此时我们对于想重做的某个 commit 提交的内容都不存在了:

1 使用git log查看提交记录:

Author: debuginn <debuginn@icloud.com>
Date:   Tue Sep 21 16:36:39 2021 +0800

    feat add 3.go

2 使用git revert命令重做操作:

➜  demo git:(master) git revert 338bf3e30983d34074f37a18b3ff80ea9bca75f0
删除 2.go
[master ef822b7] Revert "feat add 2.go"
 1 file changed, 9 deletions(-)
 delete mode 100644 2.go

再次查看 git log :

commit ef822b71c33a2dbbdaa350fddcfa14e8fc55e543 (HEAD -> master, origin/master)
Author: debuginn <debuginn@icloud.com>
Date:   Tue Sep 21 17:12:00 2021 +0800

    Revert "feat add 2.go"

    This reverts commit 338bf3e30983d34074f37a18b3ff80ea9bca75f0.

commit b0ef8f9125226af8f06ff1aba7c1f1fc83adea9b
Author: debuginn <debuginn@icloud.com>
Date:   Tue Sep 21 17:05:39 2021 +0800

    feat add 3.go

可以看到当前已经重做了一下 commit 2 的提交,已经讲 2.go 删除掉了。

可以看到 github 上面有了四次提交记录。

总结

git resetgit revert都是属于重新恢复工作区以及远程提交的方式,但这两种操作有着截然不同的结果:

  • git reset是将之前的提交记录全部抹去,将 HEAD 指向自己重置的提交记录,对应的提交记录都不复存在;
  • git revert 操作是将选择的某一次提交记录 重做,若之后又有提交,提交记录还存在,只是将指定提交的代码给清除掉。

选择合适的方式回滚自己的代码在团队合作中很重要,但是要慎重操作,不要丢失代码哦。

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值