《廖雪峰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 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
就表示status
:git 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教程》学习笔记的更多相关文章
- js学习笔记:webpack基础入门(一)
之前听说过webpack,今天想正式的接触一下,先跟着webpack的官方用户指南走: 在这里有: 如何安装webpack 如何使用webpack 如何使用loader 如何使用webpack的开发者 ...
- PHP-自定义模板-学习笔记
1. 开始 这几天,看了李炎恢老师的<PHP第二季度视频>中的“章节7:创建TPL自定义模板”,做一个学习笔记,通过绘制架构图.UML类图和思维导图,来对加深理解. 2. 整体架构图 ...
- PHP-会员登录与注册例子解析-学习笔记
1.开始 最近开始学习李炎恢老师的<PHP第二季度视频>中的“章节5:使用OOP注册会员”,做一个学习笔记,通过绘制基本页面流程和UML类图,来对加深理解. 2.基本页面流程 3.通过UM ...
- 2014年暑假c#学习笔记目录
2014年暑假c#学习笔记 一.C#编程基础 1. c#编程基础之枚举 2. c#编程基础之函数可变参数 3. c#编程基础之字符串基础 4. c#编程基础之字符串函数 5.c#编程基础之ref.ou ...
- JAVA GUI编程学习笔记目录
2014年暑假JAVA GUI编程学习笔记目录 1.JAVA之GUI编程概述 2.JAVA之GUI编程布局 3.JAVA之GUI编程Frame窗口 4.JAVA之GUI编程事件监听机制 5.JAVA之 ...
- seaJs学习笔记2 – seaJs组建库的使用
原文地址:seaJs学习笔记2 – seaJs组建库的使用 我觉得学习新东西并不是会使用它就够了的,会使用仅仅代表你看懂了,理解了,二不代表你深入了,彻悟了它的精髓. 所以不断的学习将是源源不断. 最 ...
- CSS学习笔记
CSS学习笔记 2016年12月15日整理 CSS基础 Chapter1 在console输入escape("宋体") ENTER 就会出现unicode编码 显示"%u ...
- HTML学习笔记
HTML学习笔记 2016年12月15日整理 Chapter1 URL(scheme://host.domain:port/path/filename) scheme: 定义因特网服务的类型,常见的为 ...
- DirectX Graphics Infrastructure(DXGI):最佳范例 学习笔记
今天要学习的这篇文章写的算是比较早的了,大概在DX11时代就写好了,当时龙书11版看得很潦草,并没有注意这篇文章,现在看12,觉得是跳不过去的一篇文章,地址如下: https://msdn.micro ...
- ucos实时操作系统学习笔记——任务间通信(消息)
ucos另一种任务间通信的机制是消息(mbox),个人感觉是它是queue中只有一个信息的特殊情况,从代码中可以很清楚的看到,因为之前有关于queue的学习笔记,所以一并讲一下mbox.为什么有了qu ...
随机推荐
- linux中创建和解压文档的 tar 命令教程
linux & zip & tar https://www.cnblogs.com/xgqfrms/p/9714161.html 1 linux中的tar命令 tar(磁带归档)命令是 ...
- Windows安装ElastAlert问题总结
1.运行时出现UnicodeDecodeError: ‘ascii’ codec can’t decode byte 0xb4 in position 0: invalid start byte 或 ...
- Java机器学习框架deeplearing4j入门教程
1.添加项目maven添加依赖 or 导入jar包 or 使用jvm <project xmlns="http://maven.apache.org/POM/4.0.0" x ...
- linux 配置文件(启动文件、环境文件)启动顺序
1.登录shell 登录shell时,linux会按一定规则读取启动几个配置文件: /ect/profile $HOME/.bash_profile $HOME/.bashrc $HOME/.bash ...
- Java 信号量 Semaphore 介绍
Semaphore当前在多线程环境下被扩放使用,操作系统的信号量是个很重要的概念,在进程控制方面都有应用.Java 并发库 的Semaphore 可以很轻松完成信号量控制,Semaphore可以 ...
- mysql中LIKE和REGEXP
mysql中LIKE和REGEXP都可以用来字符匹配 正则表达式REGEXP是为复杂搜索指定模式的强大方式. like用法 LIKE一般与通配符(%)和(_)两个使用 如例 SELECT prod ...
- [BZOJ2733][HNOI2010]永无乡 解题报告 启发式合并,线段树合并
好久没更新博客了,前段时间一直都在考试,都没时间些,现在终于有点闲了(cai guai)... 写了一道题,[HNOI2012]永无乡,其实是一道板子题,我发现我写了好多板子题...还是太菜了... ...
- Luogu 3385 负环 | 我有特别的SPFA技巧
这样似乎跑得快: 初始化所有的dis是0,然后枚举每个点作为起点,用DFS更新所有点的dis: 如果更新到一个栈中节点,那么有负环. #include <cstdio> #include ...
- Palindrome Number - LeetCode
目录 题目链接 注意点 解法 小结 题目链接 Palindrome Number - LeetCode 注意点 负数肯定是要return false的 数字的位数要分奇数和偶数两种情况 解法 解法一: ...
- Ants on tree
Description 从前有一个策略游戏, 叫做 蚂蚁上树 游戏中有一棵 nn 个节点, 以 11 为根的有根树 初始始每个节点都为空, 游戏系统会进行两种操作 : 1 x , 表示往 xx 节点放 ...