必学的Git

1.Git简介
Git是世界上最先进的分布式版本控制系统,没有之一。用于敏捷高效的处理各种或大或小的项目。它为我们带来了很多方便,聪明到可以每次自动记录版本的改动。

1.1四个区

  • 工作区(Working Area)

  • 暂存区(Stage)

  • 本地仓库(Local Repository)

  • 远程仓库(Remote Repository)

1.2五种状态

  • 未修改(Origin)

  • 已修改(Modified)&未追踪(Untracked)

  • 已暂存(Staged)

  • 已提交(Committed)

  • 已推送(Pushed)


2.代码提交与同步流程
2.1操作流程
第一步:文件增删改,变为已修改状态

第二步:git add ,变为已暂存状态

$ git add --all # 当前项目下的所有更改 
$ git add .  # 当前目录下的所有更改 
$ git add xx/xx.py xx/xx2.py  # 添加某几个文件 

第三步:git commit,变为已提交状态

$ git commit -m #这里写commit的描述

第四步:git push,变为已推送状态

$ git push -u origin master # 第一次需要关联上 
$ git push # 之后再推送就不用指明应该推送的远程分支了 
$ git branch # 可以查看本地仓库的分支 
$ git branch -a # 可以查看本地仓库和本地远程仓库(远程仓库的本地镜像)的所有分支

2.2图示
必学的Git_第1张图片

3.五种状态间的撤销操作
3.1已修改,但未暂存

$ git diff # 列出所有的修改 
$ git diff xx/xx.py xx/xx2.py # 列出某(几)个文件的修改 $ git checkout # 撤销项目下所有的修改 
$ git checkout . # 撤销当前文件夹下所有的修改 
$ git checkout xx/xx.py xx/xx2.py # 撤销某几个文件的修改 
$ git clean -f # untracked状态,撤销新增的文件 
$ git clean -df # untracked状态,撤销新增的文件和文件夹  # Untracked files: #  (use "git add ..." to include in what will be committed) # # xxx.py 

3.2已暂存,未提交
这个时候已经执行过git add,但未执行git commit,但是用git diff已经看不到任何修改。

因为git diff检查的是工作区与暂存区之间的差异。

$ git diff --cached # 这个命令显示暂存区和本地仓库的差异 
$ git reset # 暂存区的修改恢复到工作区 
$ git reset --soft # 与git reset等价,回到已修改状态,修改的内容仍然在工作区中 
$ git reset --hard # 回到未修改状态,清空暂存区和工作区 
git reset --hard 操作等价于 git reset 和 git checkout 2步操作

3.3已提交,未推送
执行完commit之后,会在仓库中生成一个版本号(hash值),标志这次提交。之后任何时候,都可以借助这个hash值回退到这次提交。

$ git diff   # 比较2个分支之间的差异 
$ git diff master origin/master # 查看本地仓库与本地远程仓库的差异 
$ git reset --hard origin/master # 回退与本地远程仓库一致 
$ git reset --hard HEAD^ # 回退到本地仓库上一个版本 
$ git reset --hard  # 回退到任意版本 
$ git reset --soft/git reset # 回退且回到已修改状态,修改仍保留在工作区中。

3.4已推送到远程

$ git push -f orgin master # 强制覆盖远程分支 
$ git push -f # 如果之前已经用 -u 关联过,则可省略分支名 

慎用,一般情况下,本地分支比远程要新,所以可以直接推送到远程,但有时推送到远程后发现有问题,进行了版本回退,旧版本或者分叉版本推送到远程,需要添加 -f参数,表示强制覆盖。

3.5图示
必学的Git_第2张图片

4.总结
首先,先用git status查看下当前状态。

git reset可以作用于本地仓库,用于回退/前进到任意版本,也可以作用于暂存区,用于撤销暂存区修改。有hard和soft2个参数。soft参数可以省略,soft参数表示撤销的修改仍放在工作区中。

git checkout用于撤销删除和修改,git clean -df用于撤销新增。
git diff可以查看工作区、暂存区、仓库之间的修改和差异,参数不同。

5.遇到的问题
昨天手里等于是有两个需求没有完成,我也没多想,就直接把两个需求的代码写在一个分支,其实在今天之前我根本没理解什么叫一个需求一个分支,今天完成了一个准备提交的时候才知道这是多么痛的领悟。。。第一次我直接忘了下拉更新,提示落后48个提交,但是我又已经commit 和push ,然后就要经过一系列查看commit号,reset,log,捣鼓半天,最后是把我另一个需求写了一半的代码删了,才把这个提交成功的,所以说是多么痛的领悟,不过经过这个事,我现在对于git的这些事已经弄得不能再清楚了,以后不会再出任何问题啦!还是很值得,删掉的代码智能重写喽!!!

项目提交pr流程:

(1).在写需求之前创建一个新分支,git checkout -b 新分支名

(2).git pull origin Fusion 更新代码

(3).git status 是显示工作目录和暂存区的状态

(4). git add . 是把所有修改放在暂存区

(5).git commit -m “[Change] 做出了什么修改”

(6).git branch 查看当前在那个分支

(7).git push origin + 当前分支 把修改push上去

一些比较常用的git命令:

git log 查看操作日志

git log –online 将每条日志输出为一行

git reset + commit号 本地仓库或暂存区回退到未修改的工作区

git resert –hard + commit号 暂存区回退到未修改的工作区

git checkout + 分支名 切换分支

git branch -a 显示出所有分支(包括本地分支和远程分支)

git chckout -b dev origin/dev 作用是checkout远程的dev分支,在本地起名为dev分支,并切换到本地的dev分支

你可能感兴趣的:(git)