原文链接

一.创建版本库

①初始化一个Git仓库:git init

②添加文件到Git仓库:1.git add<file> ;  2.git commit

二.时光机穿梭

①查看工作区状态,文件是否被修改过:git status

②查看修改的内容:git diff

1.版本回退

①HEAD:当前版本

②HEAD^:上个版本

③定位版本:git reset --hard commit_id

④git log:穿梭前,用git log可以查看提交历史,以便确定要回退到哪个版本

⑤git reflog:要重返未来,用git reflog查看命令历史,以便确定要回到未来的哪个版本。

2.工作区和暂存区

①工作区:就是你在电脑里能看到的目录,比如我的learngit文件夹就是一个工作区

②版本库:工作区有一个隐藏目录.git,这个不算工作区,而是Git的版本库。

③暂存区:Git的版本库里存了很多东西,其中最重要的就是称为stage(或者叫index)的暂存区。

第一步是用git add把文件添加进去,实际上就是把文件修改添加到暂存区;

第二步是用git commit提交更改,实际上就是把暂存区的所有内容提交到当前分支。

3.管理修改

①每次修改,如果不add到暂存区,就不会加入到commit中

4.撤销修改

①git checkout -- file:丢弃工作区的修改

②git reset HEAD file:把暂存区的修改撤销掉,重新放回工作区

5.删除文件

①git rm:从版本库中删除文件

三.远程仓库

1.添加远程库

①关联一个远程库:git remote add origin git@server-name:path/repo-name.git

②关联后第一次推送master分支的所有内容:git push -u origin master

③此后,每次本地提交后,只要有必要,就可以使用命令git push origin master推送最新修改

ps:由于远程库是空的,我们第一次推送master分支时,加上了-u参数,Git不但会把本地的master分支内容推送的远程新的master分支,还会把本地的master分支和远程的master分支关联起来,在以后的推送或者拉取时就可以简化命令。

2.从远程库克隆

①要克隆一个仓库,首先必须知道仓库的地址,然后使用git clone命令克隆

②Git支持多种协议,包括https,但通过ssh支持的原生git协议速度最快

四.分支管理

1.创建与合并分支

①查看分支:git branch

②创建分支:git branch<name>

③切换分支:git cheakout<name>

④创建+切换分支:git cheakout -b <name>

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

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

2.解决冲突

①查看分支合并图:git log -- graph

eg:git log --graph --pretty =oneline --abbrev -commit

3.分支管理策略

①合并分支时加--no-ff参数:普通模式合并,合并后的历史有分支,禁用fast forward

eg:git log --no-ff-m"merge with no--ff"dev

4.Bug分支

①git stash:把当前工作现场隐藏起来,去修复bug

②git stash pop:恢复工作现场同时删除stash内容

5.Feature分支

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

②如果要丢弃一个没有被合并过的分支,可以通过git branch -D <name>强行删除

6.多人协作

①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:建立本地分支和远程分支的关联

五.标签管理

1.创建标签

①git tag <name>:新建一个标签(默认为HEAD,也可以指定commit id)

②git tag -a <tagname> -m "blablabla...":可以指定标签信息

③git tag -s <tagname> -m "blablabla...":可以用PGP签名信息

④git tag:查看所有标签

2.操作标签

①git push origin <tagname>:推送一个本地标签

②git push origin --tags:推送全部未推送过的本地标签

③git tag -d <tagname>:删除一个本地标签

④git push origin :refs/tags/<tagname>:删除一个远程标签

六.使用GitHub

①在GitHub上,可以任意Fork开源仓库;

②自己拥有Fork后的仓库的读写权限;

③可以推送pull request给官方仓库来贡献代码。

七.自定义Git

1.忽略特殊文件

①忽略某些文件时,需要编写.gitignore

2.配置别名

①我们只需要敲一行命令,告诉Git,以后st就表示statusgit config --global alias.st status

eg:

$ git config --global alias.co checkout
$ git config --global alias.ci commit
$ git config --global alias.br branch
$ git config --global alias.unstage 'reset HEAD'
$ git config --global alias.last 'log -1'
git config --global alias.lg "log --color --graph --pretty=format:'%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset' --abbrev-commit"

3.搭建Git服务器

GitHub就是一个免费托管开源代码的远程仓库。但是对于某些视源代码如生命的商业公司来说,既不想公开源代码,又舍不得给GitHub交保护费,那就只能自己搭建一台Git服务器作为私有仓库使用。

例如大众点评code.dianpingoa.com

《廖雪峰Git教程》学习笔记的更多相关文章

  1. js学习笔记:webpack基础入门(一)

    之前听说过webpack,今天想正式的接触一下,先跟着webpack的官方用户指南走: 在这里有: 如何安装webpack 如何使用webpack 如何使用loader 如何使用webpack的开发者 ...

  2. PHP-自定义模板-学习笔记

    1.  开始 这几天,看了李炎恢老师的<PHP第二季度视频>中的“章节7:创建TPL自定义模板”,做一个学习笔记,通过绘制架构图.UML类图和思维导图,来对加深理解. 2.  整体架构图 ...

  3. PHP-会员登录与注册例子解析-学习笔记

    1.开始 最近开始学习李炎恢老师的<PHP第二季度视频>中的“章节5:使用OOP注册会员”,做一个学习笔记,通过绘制基本页面流程和UML类图,来对加深理解. 2.基本页面流程 3.通过UM ...

  4. 2014年暑假c#学习笔记目录

    2014年暑假c#学习笔记 一.C#编程基础 1. c#编程基础之枚举 2. c#编程基础之函数可变参数 3. c#编程基础之字符串基础 4. c#编程基础之字符串函数 5.c#编程基础之ref.ou ...

  5. JAVA GUI编程学习笔记目录

    2014年暑假JAVA GUI编程学习笔记目录 1.JAVA之GUI编程概述 2.JAVA之GUI编程布局 3.JAVA之GUI编程Frame窗口 4.JAVA之GUI编程事件监听机制 5.JAVA之 ...

  6. seaJs学习笔记2 – seaJs组建库的使用

    原文地址:seaJs学习笔记2 – seaJs组建库的使用 我觉得学习新东西并不是会使用它就够了的,会使用仅仅代表你看懂了,理解了,二不代表你深入了,彻悟了它的精髓. 所以不断的学习将是源源不断. 最 ...

  7. CSS学习笔记

    CSS学习笔记 2016年12月15日整理 CSS基础 Chapter1 在console输入escape("宋体") ENTER 就会出现unicode编码 显示"%u ...

  8. HTML学习笔记

    HTML学习笔记 2016年12月15日整理 Chapter1 URL(scheme://host.domain:port/path/filename) scheme: 定义因特网服务的类型,常见的为 ...

  9. DirectX Graphics Infrastructure(DXGI):最佳范例 学习笔记

    今天要学习的这篇文章写的算是比较早的了,大概在DX11时代就写好了,当时龙书11版看得很潦草,并没有注意这篇文章,现在看12,觉得是跳不过去的一篇文章,地址如下: https://msdn.micro ...

  10. ucos实时操作系统学习笔记——任务间通信(消息)

    ucos另一种任务间通信的机制是消息(mbox),个人感觉是它是queue中只有一个信息的特殊情况,从代码中可以很清楚的看到,因为之前有关于queue的学习笔记,所以一并讲一下mbox.为什么有了qu ...

随机推荐

  1. python自动化之时间

    cxz##############################现在时间######################### import time time.time() ############# ...

  2. Chrome神器Vimium快捷键学习记录

    今天下午折腾了一下Chrome下面的一个插件Vimium的使用,顿时发现该插件功能强大,能够满足减少鼠标的使用.至于为何要使用这个插件,源于我手腕上的伤一直没有好,使用鼠标的时候有轻微的疼痛.而且,由 ...

  3. 只会java,参加acm如何?

    作者:董适链接:https://www.zhihu.com/question/31213070/answer/51054677来源:知乎著作权归作者所有,转载请联系作者获得授权. 当然合适,有什么不合 ...

  4. 【bzoj4031】[HEOI2015]小Z的房间 解题报告

    [bzoj4031][HEOI2015]小Z的房间 Description 你突然有了一个大房子,房子里面有一些房间.事实上,你的房子可以看做是一个包含\(n*m\)个格子的格状矩形,每个格子是一个房 ...

  5. 洛谷 P1072 Hankson 的趣味题 解题报告

    P1072 \(Hankson\)的趣味题 题目大意:已知有\(n\)组\(a0,a1,b0,b1\),求满足\((x,a0)=a1\),\([x,b0]=b1\)的\(x\)的个数. 数据范围:\( ...

  6. 【poj3133】 Manhattan Wiring

    http://poj.org/problem?id=3133 (题目链接) 题意 $n*m$的网格里有空格和障碍,还有两个$2$和两个$3$.要求把这两个$2$和两个$3$各用一条折线连起来.障碍里不 ...

  7. 【poj3016】 K-Monotonic

    http://poj.org/problem?id=3016 (题目链接) 题意 给出一个数列,将一个数${a_i}$更改为${b_i}$的代价为${|a_i-b_i|}$.求将数列改为不递减的最小代 ...

  8. 单点登录(十八)----cas4.2.x客户端增加权限控制shiro

    我们在上面章节已经完成了cas4.2.x登录启用mongodb的验证方式. 单点登录(十三)-----实战-----cas4.2.X登录启用mongodb验证方式完整流程 也完成了获取管理员身份属性 ...

  9. 解题:洛谷4314 CPU监控

    题面 线段树·二重标记(什么鬼 用(a,b)标记表示先执行+a操作,然后对b取max,维护历史/当前最大值和历史/当前标记.然后我们发现区间加$x$就是$(x,-inf)$,区间赋$x$就是$(-in ...

  10. 4:JAVA UUID 生成

    GUID是一个128位长的数字,一般用16进制表示.算法的核心思想是结合机器的网卡.当地时间.一个随即数来生成GUID.从理论上讲,如果一台机器每秒产生10000000个GUID,则可以保证(概率意义 ...