《Git教程-廖雪峰》学习笔记

一.创建版本库

①初始化一个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 [email protected]: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

时间: 2024-08-08 17:32:53

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

疯狂Android讲义 - 学习笔记(二)

Android应用的用户界面编程 Android推荐使用XML布局文件来定义用户界面 ViewGroup是一个抽象类,通常使用它的子类作为容器,ViewGroup控制其子组件的分布依赖于两个内部类: ViewGroup.LayoutParams 和 ViewGroup.MarginLayoutParams 疯狂Android讲义 - 学习笔记(二),布布扣,bubuko.com

疯狂Android讲义 - 学习笔记(六)

第7章 7.1 使用简单图片 7.1.1 使用Drawable对象 7.1.2 Bitmap和BitmapFactory 7.2 绘图 7.2.1 Android绘图基础:Canvas.Paint等 Android的绘图应该继承View组件,并重写onDraw(Canvas canvas) 方法即可,Canvas代表了“依附”于指定View的画布.表7.1 Canvas的绘制方法 Paint代表了Canvas上的画笔,Paint类主要用于设置绘制风格,包括画笔颜色.画笔粗细.填充风格等. 7.2

疯狂Android讲义 - 学习笔记(八)

第10章 Service与BroadcastReceiver 10.1 Service简介 Service组件也是可执行的程序,有自己的生命周期,创建.配置Service与创建.配置Activity的过程基本相似.Service一直在后台运行,没有用户界面. 10.1.1 创建.配置Service 需要2个步骤:1 定义基础Service的子类,2 在AndroidManifest.xml文件中配置Service. Service与Activity都是从Context派生出来的,因此都可以调用C

疯狂Android讲义 - 学习笔记(五)

第五章 Android使用统一的Intent对象来封装“启动意图”,不管是启动Activity.Service组件.或者BroadcastReceiver等,提供了一致的编程模型.Intent设计有点类似于Struts2框架中的逻辑视图设计. Intent还是应用程序组件之间通信的重要媒介:数据封装成Bundle对象,Intent携带Bundle对象. 5.1 Intent对象详解 5.2 Intent的属性及intent-filter配置 5.2.1 Component属性 5.2.2 Act

疯狂Android讲义 - 学习笔记(四)

Android应用通常有多个Activity,多个Activity组成Activity栈,当前活动的Activity位于栈顶.Activity相当于Java Web开发的Servlet.当Activity处于Android应用运行时,同样受系统控制.有生命周期. 4.1 建立.配置和使用Activity 4.1.1 Activity 建立自己的Activity需要集成Activity基类,在不同的应用场景,有时也能集成Activity的子类. Activity间接或直接继承了Context.Co

疯狂Android讲义 - 学习笔记(七)

第8章 Android数据存储与IO  Java IO的数据存储可以移植到Android应用开发上来,Android系统还提供了一些专门的IO API. Android系统内置了SQLite数据库,SQLite是轻量级的,没有后台进程,整个数据库对应一个文件,这样可以非常方便的在不同设备之间移植.Android为访问SQLite提供了大量便捷的API. 8.1 使用SharedPreferences 适用于保存简单格式的数据. 8.1.1 SharedPreferences 与 Editor S

【疯狂Java讲义学习笔记】【数据类型与运算符】

[学习笔记]1.8bit = 1byte,4byte = 1word.Java中的整型数据有byte(1字节),short(2字节),int(4字节),long(8字节).Java中的浮点数据有float(4字节),double(8字节)Java中还有一个字符型char(2字节),本质也是整型Java中的布尔型boolean(1位) 2.类型转换分为自动类型转换和强制类型转换.自动类型转换,比如:范围小的数赋值给了范围大的数:空字符串和基本类型数值连接. 3.表达式类型的自动提升:当一个算术表达

【疯狂Java讲义学习笔记】【流程控制与数组】

[学习笔记]1.switch语句后的expression表达式的数据类型只能是byte.short.char.int四个整数类型.String(Java 7后才支持)和枚举类型. 2.数组的长度不可变,定义数组时候不能指定数组的长度.为数组分配空间的时候一定要进行初始化,数组初始化的方法有两种,第一种是静态初始化,在数组中直接为每个数组元素赋上初值,另一种是动态初始化,在初始化的时候指定数组的长度,由系统来为每个元素指定初值.注意的是两种初始化不能够同时使用,即既指定数组的长度,同时又为每个元素

疯狂Android讲义 - 学习笔记(三)

Android的事件处理 3.1 Android提供了两套事件处理机制:基于监听的事件处理.基于回调的事件处理. 3.2 基于监听的事件处理 3.2.1 监听的处理模型  主要涉及三类对象:EventSource.Event.EventListener. Android的事件处理机制是一种委派式(Delegation)事件处理方式:普通组件将整个事件处理委托给特定的对象(事件监听器),可以把所有可能的事件授权给不同的事件监听器来处理,也可以让一类事件都使用同一个事件监听器来处理. 事件监听类是一

《疯狂XML讲义》学习笔记

<疯狂XML讲义>主要分为五个部分.第一部分介绍了XML.DTD.XML Schema等基础知识,这些知识主要教读者如何定义有效的XML文档,这部分 内容是深入学习后面知识的基础,也是每个使用XML的开发者都应该掌握的 基础.第二部分介绍了CSS.XSLT和XPath等知识,通过使用CSS或XSLT,可 直接将XML文档当成视图技术.第三部分介绍了DOM.SAX.JAXP.dom4j. JDOM.XQuery和XQJ等,其中的DOM.SAX.JAXP.dom4j和JDOM都以结构化的 方式来创