Git时光机、Git标签、Git分支、GitHub协作

Git时光机(切换版本)

1.查看提交历史

HEAD指针指向这次分支的最后一次提交
在这里插入图片描述

版本信息一行显示【git log --pretty=oneline】

在这里插入图片描述

2.引用日志【git reflog】 (只在自己的工作区中存在)

非常重要:当HEAD指针进行切换之后,日志会受到影响(比如切换到之前的版本,那git log不能在查看这之后的提交日志,但git reflog的引用日志会保存信息)
在这里插入图片描述

3.查看当前HEAD指向版本的详情信息【git show】

git show
git show HEAD
git show HEAD+字符
//查看HEAD对应的上一条引用日志的详情信息
git show HEAD^
git show HEAD~
//查看HEAD对应的上上一条引用日志的详情信息
git show HEAD~~
git show HEAD^^
git show HEAD~数字 //查看HEAD对应的上数字条引用日志的详情信息
git show HEAD@{6} //查看对应任意引用日志对应的详情信息
在这里插入图片描述

4.git 生成的hash串,用于版本切换

在这里插入图片描述
通过这个hash串的前位数字用于版本切换(最少前4为,如果项目维护了好多年最少前七位)
在这里插入图片描述

5.切换版本【git reset --hard 版本号】

在这里插入图片描述

详解

git reset --soft 版本:回退到某个版本,保留工作区和暂存区,只回退commit的信息
git reset --mixed(默认) 版本:默认方式,回退到某个版本,只保留工作区,回退commit和add的信息
git resert --hard 版本,将会使用指定的版本覆盖工作区、暂存区(慎用)

【git revert重做一个新的版本】(取代git reset 方式回退版本的弊端)

git reset方式会使HEAD指针往回移动,从而丢失之后的提交信息

重做一个版本
git revert -n a124d9f  //-n 或者--no-commit 表示先重做,一会我自己手动提交              

重做之后(手动提交这次操作的日志 ):
在这里插入图片描述

重做多个版本
git revert -n OLD_SHA-1~..NEW_SHA-1     //区间是左开右闭,则对左边的区间用~修饰

在这里插入图片描述

Git标签

1.创建标签

创建附注标签
给当前版本打标签
git tag -a 标签名 -m "标签信息"

在这里插入图片描述

给之前的版本打标签
git tag -a 标签名 -m "标签信息" 指定版本的hash值

在这里插入图片描述

创建轻量标签

2.查看标签

3.推送标签

4.删除标签

GIt分支

在这里插入图片描述

1.创建分支

//创建并切换到新分支
git checkout -b 新分支名
//相当于
git branch 新分支名  //创建分支
git checkout 分支名  //切换分支

2.删除分支

git checkout -d 分支名

3.切换分支,并创建紧急修复分支

//先切换到主分支
//然后创建并切换到hotfix
git checkout -b hotfix
//对bug进行修复并提交

在这里插入图片描述

  1. 切换到主分支,比较差异
    在这里插入图片描述
  2. 分支合并(master版本只做了平滑移动)
git merge hotfix  //将hotfix分支合并到主分支上

在这里插入图片描述

4.删除hotfix分支
在这里插入图片描述

4.功能开发分支

1.需求完成后对开发分支进行提交
在这里插入图片描述

应该吧feature-1合并到v6而不是合并到v8,则应做的合并是v6\v8\v6合并到一起
在这里插入图片描述
合并功能分支并提交(生成一个新的版本)

git merge 功能分支名 -m "备注信息"

在这里插入图片描述

5.查看本地分支

查看分支

git branch   

查看每个分支最后一次的提交

git branch -v

在这里插入图片描述
查看已经合并的分支

git branch --merged

指定查看哪些分支合并到master

git branch --merged master

查看未合并的分支

git branch --no-merged

指定查看哪些分支未合并到master

git branch --no-merged master

回复被删除的分支(用指定的版本去创建分支)
使用引用日志中的版本号(引用日志只在开发者本地有,别人不可能看到你的引用日志然后去恢复)

git branch 被删除的分支名  hash版本号

在这里插入图片描述
重命名分支

git branch -m 旧分支名  新分支名

7.分支合并

起因:我们从master分支切出一个feature1分支进行开发,此时,你的同事完成了一次hotfix 并合并入了master分支,此时master分支已经领先于你的feature1分支了

git merge master(推荐)
git merge master

在这里插入图片描述
在这里插入图片描述

git rebase master(危险)

在记录里我们发现一些merge信息,但是我们觉得这样污染了我们的commit记录,想要保持一份干净的commit记录怎么办?

先退回到同事hotfix后合并master的步骤
在feature1分支下使用
git rebase master

具体操作:
1.git会把feature1分支里面的每个commit取消
2.把上面的临时操作保存成patch文件,存在.gti/rebase目录下
3.把feature1分支更新到最新的master分支上
4.最后把上面保存的patch文件应用到feature1分支上
在这里插入图片描述

如果两个人同在feature-1上工作,那么git rebase将会是一个危险的指令,你们两个的分支不同,那么你同事在pull远程master的时候,会丢失提交记录
在这里插入图片描述

8.远程分支

查看远程分支

在这里插入图片描述

推送分支
git push 远程仓库名 本地分支名

在这里插入图片描述

git push 远程仓库名 本地分支名:在远程仓库的别名

在这里插入图片描述
在这里插入图片描述

拉取远端分支
git fetch 远程仓库的别名 远程的分支:抓取到本地的命名

在这里插入图片描述

分支的删除
git push 远程库的别名 --delete 远程库中的分支名

在这里插入图片描述

9.Git冲突解决

解决合并冲突

冲突产生的原因:
举例:你在dev分支修改了一个文件,在此期间master分支这个文件也被修改了,master和dev都提交了对这个文件的修改
在这里插入图片描述
//手动对文件的冲突进行更改
在这里插入图片描述
手动删除分支提示信息和想要删除的内容,在加这个文件加入暂存区,即可改变文件的状态解决之前的冲突(一旦暂存这些冲突的文件,git就会给它标记为冲突已解决)
在这里插入图片描述
在这里插入图片描述

解决协作冲突

在上传到远端之前,抓取远程分支,查看远程分支与本地分支的差异
在这里插入图片描述
查看文件差异,没有问题在合并Fetch_HEAD至本地分支(git pull可能冲突报一大堆)
在这里插入图片描述

到71集

GitHub协作

1.添加合作者

在这里插入图片描述

  • 4
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值