流程介绍:
在我们日常开发中,基本上在完成每天的需求后都会通过git提交代码。
1. git add .
2. git commit -m "描述信息"
3. git push
复制代码
在每次完成这套操作之后,git会生成一个版本号,用于标识我们的每一次提交。
假设我们在master分支上开发,此时HEAD会指向master(当前分支),再指向最新(近)的一次提交。
准备一个例子
我们通过流程介绍的方式,分三次创建三个文件,提交三次。
通过git log 查看版本号。
撤销方式一 ———— git reset
使用此方式可以回退到指定版本号的版本,如果我回退到第一次提交(commit01),则在第一次提交之后的提交(commit02、commit03)都会消失。
git reset --hard 753c616e9eebc79af514c72db25131f3c8dd9ebd
git push -f 需要使用强制推送,因为现在线上代码比你本地的新
复制代码
撤销方式二 ———— git revert
git revert是用于“反做”某一个版本,以达到撤销该版本的修改的目的。比如,我们commit了三个版本(版本一、版本二、 版本三),突然发现版本二不行(如:有bug),想要撤销版本二,但又不想影响撤销版本三的提交,就可以用 git revert 命令来反做版本二。
git revert -n 9071bf91f0f2c00664b74fa7f1e807dc89ccabc3
git commit -m "revert test" (revert 完提交一下)
复制代码