国内最全IT社区平台 联系我们 | 收藏本站
华晨云阿里云优惠2
您当前位置:首页 > php开源 > 综合技术 > git常用命令整理

git常用命令整理

来源:程序员人生   发布时间:2016-07-02 13:02:26 阅读次数:3583次

前言

本文主要记录自己平时常常使用的git命令和搜集他人博客中1些经常使用命令,方便初学者理解和使用。

本文先简单介绍git工作原理,然后详细介绍git的各种使用方法。

1. git工作原理

1开始的时候,master分支是1条线,Git用master指向最新的提交,再用HEAD指向master,就可以肯定当前分支,和当前分支的提交点:

image

每次提交,master分支都会向前移动1步。

当我们创建新的分支,例如dev时,Git新建了1个指针叫dev,指向master相同的提交,再把HEAD指向dev,就表示当前分支在dev上:

image

Git创建1个分支很快,由于除增加1个dev指针,改改HEAD的指向,工作区的文件都没有任何变化!

对工作区的修改和提交就是针对dev分支了,比如新提交1次后,dev指针往前移动1步,而master指针不变:

image

假设我们在dev上的工作完成了,就能够把dev合并到master上。Git怎样合并呢?最简单的方法,就是直接把master指向dev确当条件交,就完成了合并:

image

所以Git合并分支也很快!就改改指针,工作区内容也不变!

合并完分支后,我们可以删除dev分支。删除dev分支就是把dev指针给删掉,删掉后,我们就剩下了1条master分支:

image

关于HEAD:

当前版本: HEAD
上1个版本: HEAD^,
上上1个版本: HEAD^^
之前100个版本: HEAD~100
准肯定位某次提交:commit_id

首先,我们在gitub上创建了自己的仓库,然后需要把github上的代码拉到本地。

2. 拉代码

2.1 克隆(第1次拉取代码)

第1次拉代码,叫克隆clone。点击“clone or download”,复制。如我的地址是 https://github.com/imutlxy/blog_code.git。

切换到你想放项目的目录下,然后履行:

git clone 项目地址(如:https://github.com/imutlxy/blog_code.git)

2.2 检出分支

就是把远程分支的代码checkout到本地

git checkout 分支名

2.3 从远端拉取最新代码

条件条件:已clone了某个仓库到本地,并且已检出某个分支到本地,当该分支远端分支更新时,我们可以通过git pull 来拉取最新代码到本地。

git pull  

3. 查看有哪些分支,查看当前位于哪一个分支

//只显示本地分支
git branch

//显示本地和远真个所有分支
git branch -a 

结果以下:

image

带*号的 master表示:当前位于master分支。

remotes/origin/master表示:远端只有1个master分支。

带remotes的都是远端分支。

4. 在本地新建分支,并推送到远端

1般master是主分支,放着线上的代码。我们开发1般用developer分支,所以,我们先来新建1个分支,并且把它推送到远端。

4.1 在本地新建分支

在本地新建分支:

git branch 分支名(比如这里是 developers)

履行 git branch -a 查看1下有无建成功:

image

好了,已ok了,然后我们需要切换到developer分支上

4.2 切换分支

git checkout developer

结果以下:

image

也能够直接下面这条命令来实现创建分支并切换到该分支:

git checkout -b 新建分支名

4.3 将本地新建分支推送到远端

git push origin developer

看结果,已有了1个remotes/origin/developer分支。

image

5. 删除分支

5.1 删除本地分支

从这节开始就不上图了,除非有必要。大家可以自己去敲验证的命令。

如果你新建了1个分支还没上传到远端,现在想删除它。例如

git branch --delete 分支名(这里是test)

git branch -d 分支名

5.2 强行删除本地分支

注意:如果当前分支还没有被合并,删除失败,git会提示你。如果想强行删除:

git branch -D 分支名

5.3 删除远端分支

如果分支已推送到了远端:

git push origin --delete 分支名(这里是test) 

6. 提交代码到远端

当我们修改了1些内容后,想提交到远端,可以顺次履行:

git status

git add .

git commit -m "注释:表示此次提交是完成了哪些功能"

git push origin 分支名

下面逐一讲授这些命令的含义和使用方法。

6.1 查看有哪些文件修改了

git status

以下图,红色的文件就是有改动的。BuildConfig.java,Manifest.java,R.java,这3个文件被删除,delete,README.md和MainActivity.java被修改,modify。

image

6.2 git add

git add命令主要用于把修改了的文件存到暂存区中。

添加1个文件到暂存区:(注意:需要进入到该文件所在的目录)

git add 文件名

添加全部改动的文件到暂存区:

git add .

当添加完后,被添加的文件变成了绿色。用 git status就能够看到,这里不贴图。

6.3 将索引库中的文件添加到本地仓库中

git commit -m "注释:表示这次提交甚么功能"

6.2我们将需要提交的文件添加到了索引库中,然后我们需要将这些文件提交到本地仓库。履行完 git commit 后,再用 git status 查看文件状态,发现 git add 的那些文件都没有了。

6.4 将本地仓库中的文件推送到远端

git push origin 分支名

如果这个分支是本地新建的,还没有推送到远端,用这个命令也能够同时把本地分支提交到远端,同时提交本地修改。

这时候候,你的所有改动就都push到远端了,你可以在github上看到提交记录。

7 合并分支

7.1 合并指定分支到当前分支

上面我们在test分支上完成了功能,此时我们需要把test分支修改的东西合并到developer分支上。

  • 我们先切换到developer分支:

    git checkout developer
    
  • 然后 再merge

    git merge 分支名(这里是test)
    

此时,我们就看之条件交到test分支上的内容,在developer分支也能看到了。

7.2 解决冲突再合并

如果没有冲突,那固然是最好的,但很多时候merge时会有冲突,我们需要先解决冲突再合并。

比如:我现在在test分支上,README文件内容是这样的:
image

然后我们修改成这样:

image

此时我们顺次履行

git add README.md

git commit -m "修改README"

git checkout developer

git merge test

看结果:

image

README出现conflict了,merge failed。

我们再来看看README内容:

image

呐,<<<<<<<指的是改动之前的内容,======作为分隔符,>>>>>>>指的是改动以后的内容。我们该解决冲突了,这里留下后面改动的,删掉之前的内容。然后再将修改后的文件重新提交便可。


8. 查看提交记录

//查看当前分支的提交记录
git log

//查看指定分支的提交记录
git log 分支名

9. 查看疏忽的文件

通常有些文件无需纳入 Git 的管理,也不希望它们总出现在未跟踪文件列表。通常都是些自动生成的文件,比如日志文件,或编译进程中创建的临时文件等。我们可以创建1个名为 .gitignore 的文件,列出要疏忽的文件模式。android studio创建project时会自动生成1个.gitignore 的文件。

查看疏忽文件:

cat .gitignore

以下图:

image

我们可以自己编辑 gitignore 文件,添加别的需要疏忽的文件。

10.关于撤消

10.1 撤消工作区的修改

场景1:

我修改了README.md文件,但是还没有履行 git add,此时,我不想要这些修改了,我要放弃这些修改,也就是回到之前没有任何修改的状态。

//放弃单个文件
git checkout 文件名

//放弃全部修改
git checkout .

10.2 撤消暂存区的修改

场景2:

  1. 接着上面的问题,如果我已把这些修改的文件都添加到了暂存区中,也就是我履行了git add,但还没履行 git commit,这时候如果想撤消这些修改,重新放回工作区,可以履行:

    //撤消某个文件
    git reset HEAD 文件名

    //撤消全部文件,全部放回工作区
    git reset HEAD

  2. 如果完全不想要这些暂存区中的文件,也就是撤消此次所有修改,并且不放回工作区,可以履行:

    git reset –hard

10.3 撤消本地仓库的提交

场景3:

我修改了文件,然后顺次履行了 git add ,git commit,但我还没履行 git push,此时我发现自己提交错了文件,我想撤消此次提交,回到上次提交的状态。可以履行:

git reset --hard HEAD^

我们来实际摹拟1下场景。

  1. 用git log看1下提交记录,我们看到,最近1次提交记录是“初次提交工程”,再前1次是“test。

image

  1. 然后我们修改README文件,并且提交到本地仓库,也就是履行git commit -m “修改README–1”,以下:

image

再看1下提交记录:

image

  1. 撤消刚才的提交记录,回到上1次提交记录,即”初次提交工程”。

image

看到了吗,之前的提交居然消失了!README内容也回到之前的模样。

  1. 如果你又想再回到刚才撤消记录的状态,怎样办?

    git reset –hard 刚才提交记录的版本号(这里是1883cb1df1bd670088e1cf82de18967076d1754f).到这里大家可能会问,怎样拿到这个记录的版本号呢?

    git reflog
    

image

看到没,git会记录你的每次记录!在git,是有后悔药的!!!

11. 比较提交

11.1 比较两个分支的差异

git diff master..test

11.2 查看当前分支工作区与缓冲区的差异

会详细列出修改内容

git diff

11.3 查看缓存区和上次提交的差异

显示你当前的索引和上次提交间的差异(这次git add 和 上次git commit的差异),也是下次提交时要提交的内容(staged,添加到索引中):

git diff --cached

//可以具体定位到某1个文件
git diff --cached filename

image

11.4 查看当前分支与其他指定分支的差异

git diff 指定分支名

//也以加上路径限定符,来只 比较某1个文件或目录。
git diff HEAD -- ./lib

11.5 查看有哪些文件有改动(只简单列出改动的文件名)

如果不是查看每一个文件的详细差别,而是统计1下有哪些文件被改动,有多少行被改动,就能够使用‘–stat’ 参数。

git diff --stat

以下图,BuildConfig.java,Manifest.java,R.java,README.md,MainActivity.java这几个文件被改动。

image

11.6 查看某两个版本之间的差异

git diff 版本号1 版本号2

11.7 查看某两个版本的某个文件之间的差异

git diff 版本号1:filename 版本号2:filename

12 把当前目录变成Git可以管理的仓库

当你在本地新建了1个仓库,可以通过以下命令把它变成git管理仓库:

git init

参考:

廖雪峰:Git教程

Git

Git Community Book 中文版

生活不易,码农辛苦
如果您觉得本网站对您的学习有所帮助,可以手机扫描二维码进行捐赠
程序员人生
------分隔线----------------------------
分享到:
------分隔线----------------------------
关闭
程序员人生