<a href="https://github.com/daelephant/learngit/blob/master/Git%E5%AD%A6%E4%B9%A0%E7%AC%94%E8%AE%B0/git%E5%AD%A6%E4%B9%A0%E7%AC%94%E8%AE%B0.md#git笔记" >GIT笔记:</a>
1. 工作区(Working Directory)和版本库(Repository)
说明:
工作区就是创建仓库的文件夹如(learngit文件夹就是一个工作区)
版本库就是工作区的隐藏目录.git,版本库中有暂存区(stage/index)和分支(master)
git add 实际是把文件添加到暂存区, git commit 把暂存区的内容提交到当前分支
2.创建版本库
1创建git仓库文件夹,名为:learngit
$ mkdir learngit
2进入leadngit文件夹
$ cd learngit
3初始化git仓库
$ git init
3. 添加文件
1在leangit下添加一个readme.txt文件,并编辑一些内容
2添加到仓库暂存区()在暂存区 文件会变绿
$ git add readme.txt
3提交readme.txt文件到当前分支, -m "提交说明"(只有进行 git add 后 go commit 命令才有效)
$ git commit -m "add readme.txt"
4. 修改文件
4.1 当文件在工作区时
1查看readme.txt文件内容
$ cat readme.txt
2修改readme.txt文件内容
vi readme.txt
3查看仓库状态
$ git status
4添加到仓库暂存区,并提交到分支
$ git add readme.txt
$ git commit -m "modify readme.txt"
4.2 当文件在暂存区时
1修改文件内容
vi ***
2添加到仓库暂存区
$ git add readme.txt
3提交到分支
$ git commit -m "modify readme.txt at the stage"
5. 撤销修改文件(未提交到分支)
5.1 当文件在工作区时
1执行撤销命令
$ git checkout -- readme.txt
5.2 当文件在暂存区时
1令文件回到工作区
$ git reset HEAD readme.txt
2执行撤销命令
$ git checkout -- readme.txt
6. 版本控制(无限次后悔)
说明:在Git中,HEAD表示当前版本,HEAD^表示上一版本 HEAD^^表示上上一个版本
1查看提交日志输出(完整版)
$ git log
2查看提交日志输出(精简版)
$ git log --pretty=noline
3回到上一版本
$ git reset --hard HEAD^
4回到指定版本(hard 后面添加版本号)
$ git reset --hard ea34578
5查看命令历史
$ git reflog
7. 远程仓库(github)
7.1 添加到远程库
1在github上创建一个名为learngit的空仓库
2在本地learngit仓库下运行命令
$ git remote add origin git@github.com:iphone5solo/learngit.git
3把本地内容推送到github远程库上(第一次push 参数带 -u关联远程仓库)
$ git push -u origin master
注意:如果在git push -u origin master
时出现以下错误,证明电脑没有修改远程仓库的公钥,
Permission denied (publickey).fatal: Could not read from remote repository.
Please make sure you have the correct access rightsand the repository exists.
解决方法:
1在github上点击Edit profile--> SSH and GPG keys --> new SSH key添加SHH公钥
2打开id_rsa.pub文件(/Users/iphone5solo/.ssh/id.rsa.pub)
3将id_rsa.pub文件内容拷贝到key就可以了,title随便填。
7.2 从远程库克隆
1在github上创建一个名为clonegit的仓库
2使用命令克隆仓库
$ git clone git@github.com:iphone5solo/clonegit```
####7.3 从远程仓库更新本地仓库(已关联)
$ git pull origin master
#8. 分支管理
####图文说明:
master分支是一条线,git用master指向最新的提交,在用HEAD指向master,以此才确定当前分支,和提交点。
![](http://upload-images.jianshu.io/upload_images/2926249-d10263e04bac1416.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
######1. 创建分支
当我们创建新的分支,例如newBranch,git就会新建一个指针newBranch,指向master相同的提交,再把HEAD指向newBranch,就表示当前分支在newBrach上
![](http://upload-images.jianshu.io/upload_images/2926249-9ff2b5327a11e2a7.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
######2. 新分支的修改和提交
现在对工作区的修改和提交就是针对newBranch分支了,比如新提交一次后,newBranch指针就向前移动一步,指向最新提交,而master指针指向不变。
![](http://upload-images.jianshu.io/upload_images/2926249-87c95d0c239a4be8.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
######3. 分支的合并
把newBranch合并到master上,直接把master指向newBranch的当前提交,就完成了合并。
![](http://upload-images.jianshu.io/upload_images/2926249-90c5ce3d210a14d3.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
######4. 合并完成删除分支
删除分支newBranch,就剩下一个master分支
![](http://upload-images.jianshu.io/upload_images/2926249-6d1d4b20f274783f.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
######5. 查看分支合并图解
![](http://upload-images.jianshu.io/upload_images/2926249-6a6bb331c97a0329.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
<strong>关于分支的主要命令如下</strong></p>
<ul>
<li><p>查看分支</p>
<pre><code>$ git branch
</code></pre></li>
<li><p>创建<code>newBranch</code>分支</p>
<pre><code>$ git branch newBranch
</code></pre></li>
<li><p>切换<code>HEAD</code>指向<code>newBranch</code>分支</p>
<pre><code>$ git checkout newBranch
</code></pre></li>
<li><p>创建+切换分支</p>
<pre><code>$ git checkout -b newBranck
</code></pre></li>
<li><p>合并某分支到当前分支</p>
<pre><code>$ git merge newBranch
</code></pre></li>
<li><p>普通删除<code>newBranch</code>分支</p>
<pre><code>$ git branch -d newBranch
</code></pre></li>
<li><p>强行删除<code>newBranch</code>分支</p>
<pre><code>$ git branch -D newBranch
</code></pre></li>
<li><p>查看分支合并状况</p>
<pre><code>$ git log --graph --pretty=oneline --abbrev-commit
</code></pre></li>
</ul>
<h3>9. 藏匿当前未提交的分支</h3>
<p>如: 当前在修改自己的分支<code>dev</code>,突然项目经理要求修复一个bug-07</p>
<p>解决方法: </p>
<ol>
<li><p>藏匿当前<code>dev</code>分支的工作状态</p>
<pre><code>$ git stash
</code></pre></li>
<li><p>新建一个<code>bug-07</code>分支</p>
<pre><code>$ git branch -b bug-07
</code></pre></li>
<li><p>修复bug并提交,合并<code>bug-07</code>到<code>master</code>分支</p>
<pre><code>$ git commit -m "fix the bug-07"
$ git checkout master
$ git merge --no-ff -m "merge bug-07" bug-07
</code></pre></li>
<li><p>删除<code>bug-07</code>分支</p>
<pre><code>$ git branch -d bug-07
</code></pre></li>
<li><p>查看当前<code>stash</code></p>
<pre><code>$ git stash list
</code></pre></li>
<li><p>恢复<code>dev</code>分支的工作状态,并删除stash内容</p>
<pre><code>$ git stash pop
</code></pre></li>
</ol>
<h3>10. 多人协作</h3>
<ul><li><p>查看远程库信息</p>
<pre><code>$ git remote</code></pre><ul>
<li><p>详细查看远程信息</p>
<p>```$ git remote -v```</p></li>
<li><p>推送分支到远程库</p>
<p>```$ git remote origin master```</p></li>
<li><p>抓取远程分支</p>
<p>```$ git pull origin master```</p></li>
</ul></li>
</ul>
<h3>11. 标签管理</h3>
<ul>
<li><p>创建一个标签,默认为<code>HEAD</code>当前分支添加标签</p>
<pre><code>$ git tag v1.0
</code></pre></li>
<li><p>为版本号为<code>e8b8ef6</code>添加<code>v2.0</code>标签</p>
<pre><code>$ git tag v2.0 e8b8ef6
</code></pre></li>
<li><p>为版本号为<code>6cb5a9e</code>添加带有说明的标签,<code>-a</code>指定标签名,<code>-m</code>指定说明文字</p>
<pre><code>$ git tag -a v3.0 -m "version 0.2 released" 6cb5a9e
</code></pre></li>
<li><p>根据标签查看指定分支</p>
<pre><code>$ git show v0.2
</code></pre></li>
<li><p>查看所有标签</p>
<pre><code>$ git tag
</code></pre></li>
<li><p>删除<code>v1.0</code>标签</p>
<pre><code>$ git tag -d v1.0
</code></pre></li>
<li><p>把<code>v0.9</code>标签推送到远程</p>
<pre><code>$ git push origin v0.9
</code></pre></li>
<li><p>推送所有尚未推送到远程的本地标签</p>
<pre><code>$ git push origin --tags
</code></pre></li>
<li><p>删除远程标签, 先删除本地标签,再删除远程标签</p>
<pre><code>
$ git tag -d v0.9</br>
$ git push origin :refs/tags/v0.9
</code></pre></li>
</ul>