看完我的笔记不懂也会懂----git
- Git学习笔记
- 什么是Git
- 首次使用Git
- DOS常用命令
- Git常用命令
- 关于HEAD
- 版本回退
- 工作区、暂存区与版本库
- git追踪的是修改而非文件本身
- 撤销修改
- 删除文件
- 创建ssh秘钥
- 远程仓库
- 远程仓库之远程协助
- 分支管理
- 分支管理相关命令
- 分支之解决冲突
- merge时禁用Fast Forward模式
- git stash区
- 标签管理
Git学习笔记

什么是Git
git是一个分布式版本控制系统
首次使用Git
//参数 --global代表机器上所有的仓库都默认使用这个配置
git config --global user.name "Your Name"
git config --global user.email "email@example.com"
DOS常用命令
ls //显示指定路径上所有文件或目录的信息
dir //显示指定路径上所有文件或目录的信息
pwd //查看当前路径
mkdir //创建文件夹目录
rd //删除文件夹目录
cd 路径 //切换至指定路径
Git常用命令
git init //初始化当前目录作为git仓库
git add 文件 //添加文件到git仓库的暂存区
git commit -m //提交文件到git仓库的版本库(当前分支)
git status //查看当前git仓库的状态
git diff //比较工作区与最后一次commit的不同
git log //命令显示从最近到最远的提交日志
git log --pretty=oneline //让输出的日志更加简洁
git log --graph --pretty=oneline --abbrev-commit //输出分支合并图
git reflog //查看最近的版本操作记录
rm //删除文件
关于HEAD
HEAD指向git当前的最新版本
HEAD^指向git上一个版本 HEAD^是上上个版本
跨越多个版本可以使用 HEAD~版本数
版本回退
回退到上一个commit
git reset --hard HEAD^
回退到指定版本
git reset --hard SHA号
工作区、暂存区与版本库
工作区(work directory): 就是git init后的我们能看到的那个文件夹目录
暂存区(stage/index): git add后文件存放的地方
版本库(repository): git commit后文件存放的地方
repository里面存放着
- stage,
- git自动创建的第一个分支master
- 一个指向master的指针HEAD
git add添加文件后暂存区的状态变成这样
git commit提交文件后暂存区的状态变成这样
git追踪的是修改而非文件本身
新建一个文件
git追踪的是修改
git add进stage中修改这个文件
git追踪的是文件的修改
git commit进repository中
问题出现了: 发现commit的是第一次的修改(即:git追踪的是修改)
原因在于: git追踪的是文件的修改,也就是只会commit被add进stage中的文件版本
解决方法:第一次修改 -> git add -> git commit -> 第二次修改 -> git add -> git commit第一次修改 -> git add -> 第二次修改 -> git add -> git commit
撤销修改
git checkout -- file 是用版本库的版本替换工作区的修改
还没有
git add到stage,撤销工作区的修改已经
git add到stage,撤销工作区的修改(add后再修改工作区)
上面两种情况都能用:git checkout -- file工作区已经修改,并且已经
git add到stage(修改工作区再add)
git reset [version] file 是将stage撤销到work directory//先用reset把暂存区的修改撤销掉(unstage),重新放回工作区
git reset HEAD file
//然后用checkout丢弃工作区的修改
git checkout -- file
删除文件
处理使用rm或者右键删除的文件
- 的确要删除文件
git rm file - 无操作删除,想要恢复
git checkout -- file用版本库的最新版本替换工作区的修改
创建ssh秘钥
ssh-keygen -t rsa -C "youremail@example.com"
远程仓库
关联远程仓库
git remote add origin [address]git remote add origin [branch] [address]将本地仓库推送至远程仓库
//第一次推送
git push -u [remoteName] [branchName]
//例子
git push -u origin master //以后推送
git push [remoteName] [branchName]
//例子
git push origin master //关于参数-u
作用是:可以简化git push操作,即以后git push可以代替git push origin master
列出远程仓库的分支
git remote从远程仓库克隆
git clone [address]
远程仓库之远程协助
查看远程仓库信息
git remote
git remote -V //显示更加详细(包含fetch和push地址)
在本地创建和远程分支对应的分支
git checkout -b [branchName] [remoteName]/[branchName]
建立本地分支和远程分支的关联
git branch --set-upstream branch-name origin/branch-name
多人协作的工作模式通常是这样:
- 首先,可以试图用
git push origin <branch-name>推送自己的修改 - 如果推送失败,则因为远程分支比你的本地更新,需要先用
git pull试图合并 - 如果合并有冲突,则解决冲突,并在本地提交;
- 没有冲突或者解决掉冲突后,再用
git push origin <branch-name>推送就能成功 - 如果git pull提示no tracking information,则说明本地分支和远程分支的链接关系1. 没有创建,用命令
git branch --set-upstream-to <branch-name> origin/<branch-name>
分支管理
Git中默认创建一条主分支叫做master,而HEAD指向这个主分支master,master再指向最新的commit
当我们创建新的分支,例如dev时,Git新建了一个指针叫dev,指向master相同的提交,再把HEAD指向dev,就表示当前分支在dev上
不过,从现在开始,对工作区的修改和提交就是针对dev分支了,比如新提交一次后,dev指针往前移动一步,而master指针不变
假如我们在dev上的工作完成了,就可以把dev合并到master上。Git怎么合并呢?最简单的方法,就是直接把master指向dev的当前提交,就完成了合并
合并完分支后,可以删除dev分支。删除dev分支就是把dev指针给删掉,删掉后,我们就剩下了一条master分支(最少要有一条master分支)
分支管理相关命令
创建并切换到分支
git checkout -b [branchName]
git switch -c [branchName]
关于参数 -b
git checkout命令加上-b参数表示创建并切换,相当于以下两条命令:$ git branch dev //创建分支
$ git checkout dev //切换分支
Switched to branch 'dev'
创建分支
git branch [branchName]切换分支
git checkout [branchName]查看分支
git branch合并分支
git merge [branchName]删除分支
git branch -d [branchName]
git branch -D [branchName] //用于当分支文件时进行强制删除
恢复分支
git branch [SHA1] [Version]
git branch e4d9s89 HEAD //例子
分支之解决冲突
正常的冲突情况
- 新分支上修改了文件,并正常添加、提交
- master分支上无法看到dev分支上的改动,冲突产生
解决方法:
直接git merge,此时的模式为fast-forward模式第一种冲突
新分支上修改了文件,正常添加、提交
master分支上也修改了文件且内容不同,正常添加、提交
在master分支上
git merge时,冲突产生$ git merge feature1
Auto-merging readme.txt
CONFLICT (content): Merge conflict in readme.txt
Automatic merge failed; fix conflicts and then commit the result.
master分支和feature1分支各自都分别有新的提交,变成了这样:
解决方法:
- 打开文件查看冲突处
<<<<<<< HEAD
Creating a new branch is quick & simple.
=======
Creating a new branch is quick AND simple.
>>>>>>> feature1
- 在主分支中手动修改不同处(我们希望的内容)并添加、提交
merge时禁用Fast Forward模式
git merge --no-ff -m [description] [branchName]
可以看到,不使用Fast forward模式,merge后就像这样:
git stash区
作用:当分支工作没完成不能提交,但是又有新任务需要马上做时,就可以使用git stash将当前分支中的work directory冻结起来
git stash相关命令
git stash冻结当前分支的工作区git stash list查看有哪些stashgit stash apply恢复到最近的stash,并且不删除stash信息git stash pop恢复到最近的stash,并且删除stash信息git stash apply stash@{num}恢复到指定的stashgit stash pop stash@{num}恢复到指定的stash
//实例
git status //当前在master分支
git switch -c dev //创建并切换至dev分支
//突然有紧急任务。。。。
git stash //冻结当前分支(dev)
git switch -c task / /创建并切换至紧急任务分支
//完成紧急任务
git checkout master //切换master分支,准备合并刚刚完成的紧急任务
git merge --no-ff -m 'finish task' task //合并刚刚完成的紧急任务
git switch dev //切换至dev分支
git branch -d task //删除已经完成任务了的task分支
git stash list //查看stash的列表
git stash pop //解冻刚刚的工作区并删除stash list信息
标签管理
打标签是将标签放在一个commit上,作用是:更方便、迅速的找到对应的commit,例如:
- 如果没有tag,就应该是我要恢复到
sd67gh7那个commit - 有tag的话,就应该是,我要恢复到
version1.0
注意:标签总是和某个commit挂钩。如果这个commit既出现在master分支,又出现在dev分支,那么在这两个分支上都可以看到这个标签。
标签的相关命令:
查看标签
git tag
在当前最新commit上打下标签
git tag [tagName]
在指定commit上打下标签
git tag [tagName] [SHA]
在打标签时附带说明
git tag -a [tagName] -m [description] [SHA]
查看指定tag的信息
git show [tagName]
删除tag标签
git tag -d [tagName]
推送某个标签到远程
git push origin <tagName>
推送全部标签到远程
git push origin --tags
删除远程指定标签
git push origin :refs/tags/[tagName]
看完我的笔记不懂也会懂----git的更多相关文章
- 看完我的笔记不懂也会懂----bootstrap
目录 Bootstrap笔记 知识点扫盲 容器 栅格系统 源码分析部分 外部容器 栅格系统(盒模型)设计的精妙之处 Bootstrap笔记 写在开始: 由于我对AngulaJS的学习只是一个最浅显的过 ...
- 看完我的笔记不懂也会懂----AngulaJS
目录 Angular.js学习笔记 ng-app(指令) ng-model ng-init angular之表达式 双向数据绑定 数据流向的总结 作用域对象 控制器对象 依赖对象与依赖注入 命令式与声 ...
- 看完我的笔记不懂也会懂----Node.js
Node.js 学习 - 命令行窗口 - 进程与线程 - ECMAScript的缺点 - Node模块化 - Node中的全局对象 - 包 package - NPM包管理器 (Node Packag ...
- 看完我的笔记不懂也会懂----javascript模块化
JavaScript模块化 模块化引子 模块化的历史进化 模块化规范 CommonJS规范 Node.js(服务器端) 下项目的结构分析 browerify(浏览器端) 下项目的结构分析 AMD规范 ...
- 看完我的笔记不懂也会懂----less
目录 Less学习 语法篇 注释 变量 映射(Maps) @规则嵌套和冒泡 less中的嵌套规则 less中的混合 less的运算 extend延伸/继承 less忽略编译(转义) 导入(Import ...
- 看完我的笔记不懂也会懂----MongoDB
MongoDb数据库学习 - 数据库的分类 - 数据库基本概念 - MongoDB常用指令 - MongoDB的CURD - sort({key:*[1,-1]}).limit(num).skip(n ...
- 看完我的笔记不懂也会懂----MarkDown使用指南
目录 语法 [TOC] 自动生成目录 1. 标题 2. 文本强调 3. 列表 4. 图片 5. 超链接 6. 文本引用 7. 分割线 8. 代码 9. 任务列表 (MPE专属) 10. 表格 11. ...
- 看完我的笔记不懂也会懂----ECMAscript 567
目录 ECMAscript 567 严格模式 字符串扩展 数值的扩展 Object对象方法扩展 数组的扩展 数组方法的扩展 bind.call.apply用法详解 let const 变量的解构赋值 ...
- 看完我的笔记不懂也会懂----Ajax
Ajax(Asynchronous JavaScript And XML) - 本次学习所用到的插件 - XML - JSON - 关于AJAX - HTTP协议 - AJAX重点之XMLHttpRe ...
随机推荐
- 在Android用vulkan完成蓝绿幕扣像
效果图(1080P处理) 因为摄像头开启自动曝光,画面变动时,亮度变化导致扣像在转动时如上. 源码地址vulkan_extratest 这个demo主要测试二点,一是测试ndk camera集成效果, ...
- SCZ 20170812 T1 HKJ
因为题面实在是太过暴力,就不贴链接了--我自己重新写一下题面吧-- 题目描述 给定一张带权有向图,设起点为1,终点为n,每个点除编号外还有一个序号,要求输出从起点至终点的最短路经过的点的序号和最短距离 ...
- 【uva 753】A Plug for UNIX(图论--网络流最大流 Dinic)
题意:有N个插头,M个设备和K种转换器.要求插的设备尽量多,问最少剩几个不匹配的设备. 解法:给读入的各种插头编个号,源点到设备.设备通过转换器到插头.插头到汇点各自建一条容量为1的边.跑一次最大流就 ...
- Codeforces Round #171 (Div. 2) B. Books (模拟队列)
题意:有一组数,问子数组和最大不超过\(t\)的最多元素个数. 题解:用数组模拟队列,不断的往里面放,队列中的元素之和大于\(t\),就不断地从队头弹出直到满足条件,维护一个最大值即可. 代码: in ...
- Nginx 四层负载均衡
目录 四层负载均衡概述 配置七层负载均衡 配置四层负载均衡 四层负载均衡概述 四层负载均衡是基于IP+端口的负载均衡,七层负载均衡是基于URL或主机名等应用层信息的负载均衡. 其他层负载均衡(转载): ...
- 二进制方式安装docker(非root用户启动docker)
二进制方式安装docker(非root用户启动docker) 一.下载安装包: 地址:https://download.docker.com/linux/static/stable/x86_64/ 这 ...
- VS2010的单元测试(二)
四.附加测试属性 附加测试属性,在默认生成的测试代码是使被注释掉的,取消注释就可以使用. 例如,要在执行测试前,输出测试开始时间,在执行测试后,输出测试结束时间.代码如下: [ClassInitial ...
- 【非原创】LightOJ-1274 Beating the Dataset【期望dp】
学习博客:戳这里
- 关于FFT的一些理解,以及如何手工计算FFT加深理解和验证正确性
总结缺少逻辑性和系统性,主要便于自己理解和记忆 关于一维FFT的 于是复系数Cn是图像傅里叶变换的yn列向量 于是我们看到最后引入,Cn这个复系数的模来表征频率波的振幅记为Sn(即简谐波叠加的数量 然 ...
- Linux 驱动框架---模块参数
Linux 模块的参数 通过在内核模块中定义模块参数从而可以在安装模块时通过insmod module_name paramname=param形式给模块传递参数.如果安装模块是传参数则将使用模块内定 ...