- 修改文件:你修改了本地代码。
git add <file>
:你将这些修改的文件添加到暂存区。git commit -m "<message>"
:你将暂存区的更改提交到本地仓库,形成一个版本。git push
:你将本地的提交推送到远程仓库- 要随时掌握工作区的状态,使用
git status
命令。 - 如果
git status
告诉你有文件被修改过,用git diff
可以查看修改内容。 - 在Git中,用
HEAD
表示当前版本,也就是最新的提交1094adb...
(注意我的提交ID和你的肯定不一样),上一个版本就是HEAD^
,上上一个版本就是HEAD^^
,当然往上100个版本写100个^
比较容易数不过来,所以写成HEAD~100
-
现在,我们要把当前版本
append GPL
回退到上一个版本add distributed
,就可以使用git reset
命令:$ git reset --hard HEAD^ HEAD is now at e475afc add distributed
--hard
参数有啥意义?--hard
会回退到上个版本的已提交状态,而--soft
会回退到上个版本的未提交状态,--mixed
会回退到上个版本已添加但未提交的状态。现在,先放心使用--hard
。 -
最新的那个版本
append GPL
已经看不到了!好比你从21世纪坐时光穿梭机来到了19世纪,想再回去已经回不去了,肿么办?办法其实还是有的,只要上面的命令行窗口还没有被关掉,你就可以顺着往上找啊找啊,找到那个
append GPL
的commit id
是1094adb...
,于是就可以指定回到未来的某个版本:$ git reset --hard 1094a HEAD is now at 83b0afe append GPL
版本号没必要写全,前几位就可以了,Git会自动去找。当然也不能只写前一两位,因为Git可能会找到多个版本号,就无法确定是哪一个了。
-
Git的版本回退速度非常快,因为Git在内部有个指向当前版本的
HEAD
指针,当你回退版本的时候,Git仅仅是把HEAD从指向append GPL
:┌────┐ │HEAD│ └────┘│└──▶ ○ append GPL│○ add distributed│○ wrote a readme file
改为指向
add distributed
:┌────┐ │HEAD│ └────┘││ ○ append GPL│ │└──▶ ○ add distributed│○ wrote a readme file
然后顺便把工作区的文件更新了。所以你让
HEAD
指向哪个版本号,你就把当前版本定位在哪。现在,你回退到了某个版本,关掉了电脑,第二天早上就后悔了,想恢复到新版本怎么办?找不到新版本的
commit id
怎么办?在Git中,总是有后悔药可以吃的。当你用
$ git reset --hard HEAD^
回退到add distributed
版本时,再想恢复到append GPL
,就必须找到append GPL
的commit id。Git提供了一个命令git reflog
用来记录你的每一次命令 HEAD
指向的版本就是当前版本,因此,Git允许我们在版本的历史之间穿梭,使用命令git reset --hard commit_id
。- 穿梭前,用
git log
可以查看提交历史,以便确定要回退到哪个版本。 - 要重返未来,用
git reflog
查看命令历史,以便确定要回到未来的哪个版本。
git常用操作
2025/5/14 13:43:51
来源:https://blog.csdn.net/weixin_46532327/article/details/144633717
浏览:
次
关键词:git常用操作
版权声明:
本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。
我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com