Git 学习第三天(一)
远程克隆:
在github新建一个仓库,起名为gitskills

勾选此项,会自动创建一个readme.md文件,然后通过命令
git clone git@github.com:Your.name/gitskills.git
克隆到本地仓库中

比如,我在gitskills 下添加了一个文件,那么,想同步推送到github上,就需先进去gitskills文件夹
cd gitskills
然后再执行 git add git commit git push 等草做推送到远程仓库。
_____________________________________________________________
分支管理:
创建分支 dev ,然后切换到 dev 分支,
git checkout -b dev
加上 -b 参数是指创建并切换,
实际上,这相当于两条命令
git branch dev ------- 创建分支
git checkout dev --------- 切换分支
git branch ------ 显示所有分支

当前分支前会有 * 号
当前分支的操作不会影响其它分支,比如,我在dev分支下,对readme.txt 文件修改了内容,并且推送到版本库中,然后切换回master分支,查看readme.txt内容,发现,并没有改动.
git checkout master -------切换分支到master
将dev分支合并到master分支
git marge dev ----------- 将dev分支合并到当前分支
在dev修改的内容会合并到master上,在master分支上查看内容,发现,master分支下的readme.txt文件内容增加了再dev分支下的修改.
使用完dev 分支,我们就可以将之删除掉,
git branch -d dev
此时,再查看
git branch ,分支就只有master 了.
解决冲突:
我们创建一个分支 feature1,
git checkout -b feature1
然后在当前分支下修改readme.txt

git add 提交到暂存库 git commit 提交到版本库
接下来,切换回master分支,修改readme.txt 内容为

git add 提交到暂存库 git commit 提交到版本库
然后合并feature1到master
git merge feature1

果然冲突了!Git告诉我们,readme.txt文件存在冲突,必须手动解决冲突后再提交。git status也可以告诉我们冲突的文件:

查看 master 分支下readme.txt

HEAD 即 master 分支下为:

feature1 分支下为:

此时,需要我们手动解决冲突,修改为:

git add 提交到暂存库 git commit 提交到版本库
查看文件:

用带参数的git log也可以看到分支的合并情况:

最后,删除feature1分支:
$ git branch -d feature1
Deleted branch feature1 (was 75a857c).git log --graph命令可以看到分支合并图。
Git 学习第三天(一)的更多相关文章
- Git 学习(三)本地仓库操作——git add & commit
Git 学习(三)本地仓库操作——git add & commit Git 和其他版本控制系统如SVN的一个不同之处就是有暂存区的概念.这在上文已有提及,本文具体说明什么是工作区及暂存区,以及 ...
- Git学习(三)——暂存区、远程仓库、增删改管理
一.工作区和暂存区 工作区(Working Directory) 就是在你的电脑里能看到的目录 版本库(Repository) 工作区中的一个隐藏目录.git,这个不算工作区,而是Git版本库.Git ...
- Git学习笔记(三)
Git提交相关内容 在Git提交时,会保存一个提交对象,该对象包括一个指向暂存区内容快照的指针,包括本次提交作者等相关附属信息,包括零个或多个指向该提交对象的父对象指针:首次提交时是没有祖先,普通提交 ...
- Git学习教程三之分支管理
实战流程: 1:代码库克隆一份至本地 2:新分支操作 2.1 在需要的文件中创建并指向新的分支方便写代码 git checkout -b <name> 2 ...
- Git 学习第三天(二)
默认情况下, Git合并是采用"fast forward"模式,但这种模式下,如果删除分支,会丢掉分支信息 禁用 fast forward 模式: git merge --no-f ...
- git学习(三):版本控制
查看每次修改日志 git log 会显示每次修改的日期和相应提交的commit 版本控制 git reset --hard <版本id> 这里的id可以是HEAD^(上一个) HEAD^^ ...
- git学习笔记三
1.每个分支的历史版本维护信息位置是.git/logs/refs/heads/master,这个位置的信息是文本文件,不是引用. harvey@harvey-Virtual-Machine:~/dem ...
- Git学习笔记三--管理修改、撤销修改、删除文件
1.管理修改 什么是修改?比如你新增了一行,这就是一个修改,删除了一行,也是一个修改,更改了某些字符,也是一个修改,删了一些又加了一些,也是一个修改,甚至创建一个新文件,也算一个修改. 为什么说Git ...
- Git学习总结三(工作区和暂存区、撤销修改)
工作区和暂存区 工作区(Working Directory) 就是你在电脑里能看到的目录,比如我的learngit文件夹就是一个工作区: 版本库(Repository) 工作区有一个隐藏目录.git, ...
随机推荐
- JS 判断是否为null
1.判断undefined: var tmp = undefined; if (typeof(tmp) == "undefined"){ alert("undefined ...
- 在IIS7以上导出所有应用程序池的方法批量域名绑定(网站绑定)
在IIS7+上导出所有应用程序池的方法: %windir%/system32/inetsrv/appcmd list apppool /config /xml > c:/apppools.xml ...
- 21. Blog接口开发
一般的系统由登录.增删改查所组成.我们的Blog同样如此.我们会开发登录.创建博客.删除博客.修改博客.查询博客等功能.话不多说,我们直接展开实践吧. 思路分析 创建项目.既然我们要创建一个blog, ...
- CMDB 调研报告
基础概念 1.什么是CMDB CMDB——配置管理数据库,通过识别.控制.维护,检查企业的IT资源,从而高效控制与管理不断变化的IT基础架构与IT服务,并为其它流程,例如事故管理.问题管理.变更管理. ...
- Django 模型层关系映射
一.一对一映射 1.什么是一对一 A表中的一条记录只能与B表中的一条记录相关联如:一夫一妻制 2.语法 允许在关联的两个类的任何一个类中 增加: 属性 = models.OneToOneField(E ...
- overflow:hidden失效
overflow:hidden失效 为了页面的健壮性,我们常常需要使用overflow:hidden.有时候是为了防止布局被撑开,有时候是为了配合其它规则实现文字截断,还有时候纯粹是为了创建块级上下文 ...
- 几道JS代码手写面试题
几道JS代码手写面试题 (1) 高阶段函数实现AOP(面向切面编程) Function.prototype.before = function (beforefn) { let ...
- Linux使用yum install 安装程序时,提示“另外一个程序锁定了 yum;等待它退出……”
Linux使用yum install 安装程序时,提示“另外一个程序锁定了 yum:等待它退出……” 原因: yum命令一次只能安装一个软件,所以当你下载安装第二个软件包时,系统进程锁会锁定yum,这 ...
- mac 创建多个全局Path
cd ~ 进入根目录 (没有这个文件 先touch .bash_profile) open -e .bash_profile 打开编辑然后保存 JAVA_HOME=/Library/Java/Java ...
- 负载均衡实现故障vip自动漂移
环境说明演示vip自动漂移 192.168.237.50 192.168.237.51 vip: 192.168.237.5 keepalived开源软件实现 keepalived可以实现当vip挂的 ...