8月更文挑战第3天 | Git 学习笔记 03

95 阅读3分钟

携手创作,共同成长!这是我参与「掘金日新计划 · 8 月更文挑战」的第3天,点击查看活动详情

Git 的基础操作

修改、提交、推送

首先先来理解下 Git 工作区、暂存区和版本库概念:

g-5.png

  • 工作区:本地工作目录的文件夹

  • 版本库:工作区有一个隐藏目录 .git,其是 Git 的版本库(.git 文件夹:初次对本地文件夹使用 git init 命令,即可得到)

  • 暂存区:一般存放在 .git 目录下的 index 文件(.git/index)中

故把本地修改的文件推送到GitHub,分以下三步执行的:

  1. 修改 保存到暂存区》:先查看查看整个仓库的状态,使用git status命令:
git status

若有更改未提交,再使用git add命令,把文件修改添加到暂存区:

git add .
  1. 提交 至本地版本库》:用git commit提交更改到版本库(当前分支->main) (在初始化创建Git版本库时,Git自动为我们创建了唯一一个main分支,所以,现在,git commit就是往main分支上提交更改。)
git commit -m "xxx"
  1. 《然后 推送 到 GitHub 远程仓库》:

使用命令:

git push

然后等待即可。

而后可查看提交历史,使用命令 git log,它用来查看版本库的提交历史记录。

$ git log

> commit d98c961257dcc92863a5a792749b1e94caab69c2 (**HEAD ->** **main**, **origin/main**)

执行 git log 查看提交记录时,十六进制序列号就是提交版本号,这是很重要的信息,每个提交都有自己单独的版本号,就像公民身份证号一样。

版本回退撤销修改

发现文件内容有误需要修改,但是已经推送到版本库,怎么办?

方法一(正向推送):

修改此文件后,重新推送一次覆盖,将文件添加到暂存区(git add)-> 提交(git commit)-> 推送(git push)。

方法二(逆向回退):

分多种情况,先上图(虚线箭头为逆向回退)

g-6.png

版本库的回滚与撤销

  • 撤销当前提交回至 暂存区
git reset  --sort [版本号]     

版本号用 git log 可查看,输入前5~7位即可。

  • 回滚的版本到 工作区(工作区中未修改的文件区域):
git reset  --hard [版本号]
  • 回滚的版本回到 工作区(工作区中已修改的文件区域):
git reset  --mix [版本号]

暂存区的撤销

  • 暂存区 里的文件或文件夹移到 工作区 :
git reset -- [文件名]

工作区的撤销

将工作区里的 修改状态 移到工作区 未修改状态 :

git checkout -- [文件名]

后悔药

首先,Git必须知道当前版本是哪个版本,在Git中,用HEAD表示当前版本,上一个版本就是HEAD^,上上一个版本就是HEAD^^,表示第 n 个写成HEAD~n

查看所有历史版本信息 (包括回滚或删除过的):

git reflog

输出:

225f966 HEAD@{5}: pull -r origin main (pick): first commit

例如,其中 225f966 为第一次提交的版本

找到需要回到的版本号,再使用回滚撤销命令即可。 例如:

git reset --hard 225f966

输出:

HEAD is now at 225f96 append GPL

小彩蛋

介绍一个超级实用、使用频率极高的命令

查看分支信息:

git branch -avv

可显示每个(本地)分支当前指向的提交记录的哈希值,以及和其上游分支的相对位置(如果有的话)。