Linux程序员Git使用

Git操作详细总结

2017-09-04  本文已影响91人  _Cancer

Git的使用

基础操作

PS D:\learngit> git status
On branch master

Changes not staged for commit:

  (use "git add <file>..." to update what will be committed)

  (use "git checkout -- <file>..." to discard changes in working directory)

        modified:   readme.txt

no changes added to commit (use "git add" and/or "git commit -a")
PS D:\learngit> git diff readme.txt

diff --git a/readme.txt b/readme.txt

index d8036c1..7b4104a 100644

--- a/readme.txt

+++ b/readme.txt

@@ -1,2 +1,2 @@

-Git is a version control system.
+Git is a distributed  version control system.

 Git is free software.

\ No newline at end of file
PS D:\learngit> git log
commit 7e4d2e7ca2c64acba9d4580112f2d111681ae30e
Author: Sunxin <sunxin0630@gmail.com>
Date:   Wed Jun 28 16:53:17 2017 +0800

    append GPL

commit 8ba42d2299510a66489741269a789e9a3fa31691
Author: Sunxin <sunxin0630@gmail.com>
Date:   Wed Jun 28 16:51:36 2017 +0800

    add distributed

commit 67ae9c91bce5b91e54a722d091f13c1de425b9a3
Author: Sunxin <sunxin0630@gmail.com>
Date:   Wed Jun 28 16:36:25 2017 +0800

    wrote a readme file
    
PS D:\learngit> git log --pretty=oneline
7e4d2e7ca2c64acba9d4580112f2d111681ae30e append GPL
8ba42d2299510a66489741269a789e9a3fa31691 add distributed
67ae9c91bce5b91e54a722d091f13c1de425b9a3 wrote a readme file

版本回退

PS D:\learngit> git reset --hard HEAD^
HEAD is now at 8ba42d2 add distributed
PS D:\learngit> cat readme.txt
Git is a distributed  version control system.
Git is free software.
PS D:\learngit> git reset --hard 7e4d2e7
HEAD is now at 7e4d2e7 append GPL
PS D:\learngit> cat readme.txt
Git is a distributed  version control system.
Git is free software distributed under the GPL.
PS D:\learngit> git reflog
7e4d2e7 HEAD@{0}: reset: moving to 7e4d2e7
8ba42d2 HEAD@{1}: reset: moving to HEAD^
7e4d2e7 HEAD@{2}: commit: append GPL
8ba42d2 HEAD@{3}: commit: add distributed
67ae9c9 HEAD@{4}: commit (initial): wrote a readme file

工作区和暂存区

工作区(Working Directory):能看到的一个目录

暂存区(stage):隐藏目录不算工作区,而是版本库,版本库中存放着名为stage or index 的暂存区,还有git自动为我们创建的第一个分支master,以及指向master的一个指针HEAD


管理修改

为什么Git比其他版本控制系统设计的优秀?因为git跟踪管理的是文件的修改,而非文件。

小结:每次修改,如果不add到暂存区,那就不会加入到commit


撤销修改


删除文件

**`git checkout -- test.txt`** 用版本库里面的版本替换工作区的版本,一键还原

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


分支管理

使用情景:

​ 假设你准备开发一个新功能,但是需要两周才能完成,第一周你写了50%的代码,如果立刻提交,由于代码还没写完,不完整的代码库会导致别人不能干活了。如果等代码全部写完再一次提交,又存在丢失每天进度的巨大风险。现在有了分支,就不用怕了。你创建了一个属于你自己的分支,别人看不到,还继续在原来的分支上正常工作,而你在自己的分支上干活,想提交就提交,直到开发完毕后,再一次性合并到原来的分支上,这样,既安全,又不影响别人工作。

分支的切换时使用HEAD指针,所以git切换分支速度很快。


创建与合并分支

解决冲突

当两个分支修改了文件的同一个地方并且都分别有了新的提交,在这种情况下,Git无法执行“快速合并”,只能试图把新的提交合并起来,这样就可能造成冲突。我们必须手动解决冲突之后再提交,git status 也可以查看冲突的文件

PS D:\learngit> git status
On branch master
You have unmerged paths.
  (fix conflicts and run "git commit")

Unmerged paths:
  (use "git add <file>..." to mark resolution)

        both modified:   readme.txt

no changes added to commit (use "git add" and/or "git commit -a")

也可以直接查看源文件

Git is a distributed version control system.
Git is free software distributed under the GPL.
Git has a mutable index called stage.
Git tracks changes of files.
Creating a new branch is quick AND simple.
PS D:\learngit> git log --graph --pretty=oneline --abbrev-commit
*   2b7d8c2 conflict fixed
|\
| * f8cde07 AND simple
* | ec07ee4 & simple
|/
* 0057b61 branch test
* 5fc1cd2 remove test.txt
* e1161a9 add a test file

分支策略

在实际开发中,我们应该按照几个基本原则进行分支管理:

首先,master分支应该是非常稳定的,也就是仅用来发布新版本,平时不能在上面干活;

那在哪干活呢?干活都在dev分支上,也就是说,dev分支是不稳定的,到某个时候,比如1.0版本发布时,再把dev分支合并到master上,在master分支发布1.0版本;

你和你的小伙伴们每个人都在dev分支上干活,每个人都有自己的分支,时不时地往dev分支上合并就可以了。

所以,团队合作的分支看起来就像这样:

git-br-policygit-br-policy

Bug分支

修复bug时,我们会通过创建新的bug分支进行修复,然后合并,最后删除;

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

Feature分支

当需要开发一个新功能的时候,最好开一个Feature分支进行开发。在上面开发完成,合并,最后删除Feature分支。


多人协作

推送分支

把该分支上的所有本地提交推送到远程库。推送时,要指定本地分支,这样,Git就会把该分支推送到远程库对应的远程分支上

抓取分支

多人协作的工作模式:

  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 branch-name origin/branch-name


标签管理(tag)

用来为发布的正式版打上版本号

  PS D:\learngit> git tag v0.9 ac3f8e4
  PS D:\learngit> git tag
  v0.8
  v1.0
上一篇 下一篇

猜你喜欢

热点阅读