git教程——简单总结

1 建立版本库:git

  • 初始化一个Git仓库,使用git init命令。
  • 添加文件到Git仓库,分两步:

 (1)使用命令git add <file>,注意,可反复屡次使用,添加多个文件;github

 (2)使用命令git commit -m <message>,完成。app

2 时光穿梭:fetch

  • 要随时掌握工做区的状态,使用git status命令。
  • 若是git status告诉你有文件被修改过,用git diff <file>能够查看修改内容。

2.1 版本回退:指针

  • HEAD指向的版本就是当前版本,所以,Git容许咱们在版本的历史之间穿梭,使用命令git reset --hard commit_id

    在Git中,用HEAD表示当前版本, 上一个版本就是HEAD^,上上一个版本就是HEAD^^,固然往上100个版本写100个^比较容易数不过来,因此写成HEAD~100code

  • 穿梭前,用git log能够查看提交历史,以便肯定要回退到哪一个版本。
  • 要重返将来,用git reflog查看命令历史,以便肯定要回到将来的哪一个版本。

2.2 管理修改:orm

  • Git是跟踪修改的,每次修改,若是不用git add到暂存区,那就不会加入到commit中。

2.3 撤销修改:blog

  • 场景1:当你改乱了工做区某个文件的内容,想直接丢弃工做区的修改时,用命令git checkout -- file。

git checkout实际上是用版本库里的版本替换工做区的版本,不管工做区是修改仍是删除,均可以“一键还原”。开发

  • 场景2:当你不但改乱了工做区某个文件的内容,还添加到了暂存区时,想丢弃修改,分两步,第一步用命令git reset HEAD <file>,就回到了场景1,第二步按场景1操做。

用命令git reset HEAD <file>能够把暂存区的修改撤销掉(unstage),从新放回工做区;git reset命令既能够回退版本,也能够把暂存区的修改回退到工做区。rem

  • 场景3:已经提交了不合适的修改到版本库时,想要撤销本次提交,参考版本回退一节,不过前提是没有推送到远程库。

2.4 删除文件:

  • 命令git rm用于删除一个文件。若是一个文件已经被提交到版本库,那么你永远不用担忧误删,可是要当心,你只能恢复文件到最新版本,你会丢失最近一次提交后你修改的内容

$ rm test.txt

3 分支管理

查看分支:git branch

建立分支:git branch <name>

切换分支:git checkout <name>

建立+切换分支:git checkout -b <name>

合并某分支到当前分支:git merge <name>

删除分支:git branch -d <name>

3.1解决冲突

当Git没法自动合并分支时,就必须首先解决冲突。解决冲突后,再提交,合并完成。

解决冲突就是把Git合并失败的文件手动编辑为咱们但愿的内容,再提交。

用git log --graph命令能够看到分支合并图。

3.2分支管理策略

Git分支十分强大,在团队开发中应该充分应用。

合并分支时,加上--no-ff参数就能够用普通模式合并,合并后的历史有分支,能看出来曾经作过合并,而fast forward合并就看不出来曾经作过合并。

$ "merge with no-ff"git merge --no-ff -mdev
Merge'recursive'made by thestrategy.
1readme.txt |+
11file changed,insertion(+)

3.3 Bug分支

修复bug时,咱们会经过建立新的bug分支进行修复,而后合并,最后删除;

当手头工做没有完成时,先把工做现场git stash一下,而后去修复bug,修复后,再git stash pop,回到工做现场。

(用git stash list命令查看刚才保存的工做现场,Git把stash内容存在某个地方了,可是须要恢复一下,有两个办法:

一是用git stash apply恢复,可是恢复后,stash内容并不删除,你须要用git stash drop来删除;

另外一种方式是用git stash pop,恢复的同时把stash内容也删了。)

3.4 Feature分支

开发一个新feature,最好新建一个分支;

若是要丢弃一个没有被合并过的分支,能够经过git branch -D <name>强行删除。

3.5 多人协做

多人协做的工做模式一般是这样:

  1. 首先,能够试图用git push origin <branch-name>推送本身的修改;
  2. 若是推送失败,则由于远程分支比你的本地更新,须要先用git pull试图合并;
  3. 若是合并有冲突,则解决冲突,并在本地提交;
  4. 没有冲突或者解决掉冲突后,再用git push origin <branch-name>推送就能成功!

若是git pull提示no tracking information,则说明本地分支和远程分支的连接关系没有建立,用命令git branch --set-upstream-to <branch-name> origin/<branch-name>。

小结:

  • 查看远程库信息,使用git remote -v;
  • 本地新建的分支若是不推送到远程,对其余人就是不可见的;
  • 从本地推送分支,使用git push origin branch-name,若是推送失败,先用git pull抓取远程的新提交;
  • 在本地建立和远程分支对应的分支,使用git checkout -b branch-name origin/branch-name,本地和远程分支的名称最好一致;
  • 创建本地分支和远程分支的关联,使用git branch --set-upstream branch-name origin/branch-name;
  • 从远程抓取分支,使用git pull,若是有冲突,要先处理冲突。

3.6 rebase

  • rebase操做能够把本地未push的分叉提交历史整理成直线;
  • rebase的目的是使得咱们在查看历史提交的变化时更容易,由于分叉的提交须要三方对比。

4 标签管理

发布一个版本时,咱们一般先在版本库中打一个标签(tag),这样,就惟一肯定了打标签时刻的版本。未来不管何时,取某个标签的版本,就是把那个打标签的时刻的历史版本取出来。因此,标签也是版本库的一个快照。

Git的标签虽然是版本库的快照,但其实它就是指向某个commit的指针(跟分支很像对不对?可是分支能够移动,标签不能移动),因此,建立和删除标签都是瞬间完成的。

tag就是一个让人容易记住的有意义的名字,它跟某个commit绑在一块儿。

4.1 建立标签

  • 命令git tag <tagname>用于新建一个标签,默认为HEAD,也能够指定一个commit id;
  • 命令git tag -a <tagname> -m "blablabla..." 建立带有说明的标签,用-a指定标签名,-m指定说明文字;
  • 命令git tag能够查看全部标签。
  • 命令git show <tagname>能够查看标签信息和说明文字。
$ 0  默认标签是打在最新提交的commit上git tag v1.
$ 09找到历史提交的commit id,而后打上标签git tag v.f52c633    也能够

4.2 操做标签

  • 命令git push origin <tagname>能够推送一个本地标签;
  • 命令git push origin --tags能够推送所有未推送过的本地标签;
  • 命令git tag -d <tagname>能够删除一个本地标签;
  • 命令git push origin :refs/tags/<tagname>能够删除一个远程标签。

一个本地库同时关联到github和码云

使用多个远程库时,咱们要注意,git给远程库起的默认名称是origin,若是有多个远程库,咱们须要用不一样的名称来标识不一样的远程库。

仍然以learngit本地库为例,咱们先删除已关联的名为origin的远程库:

git remote rm origin

而后,先关联GitHub的远程库:

@githubcom:git remote add github git.michaelliao/learngit.git

注意,远程库的名称叫github,不叫origin了。

接着,再关联码云的远程库:

@giteecom:git remote add gitee git.liaoxuefeng/learngit.git

一样注意,远程库的名称叫gitee,不叫origin

如今,咱们用git remote -v查看远程库信息,能够看到两个远程库:

git remote -v
@giteecom:gitee    git.liaoxuefeng/learngit.git (fetch)
@giteecom:gitee    git.liaoxuefeng/learngit.git (push)
@githubcom:github    git.michaelliao/learngit.git (fetch)
@githubcom:github    git.michaelliao/learngit.git (push)

若是要推送到GitHub,使用命令:

git push github master

若是要推送到码云,使用命令:

git push gitee master

这样一来,咱们的本地库就能够同时与多个远程库互相同步:

 

 

 

参考来源:https://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000

相关文章
相关标签/搜索