git的版本回退,分支以及不同仓库的版本合并

git切换版本

  • 初始化一个git仓库,创建Demo1.txt,提交至本地仓库,创建Demo2.txt,提交至本地仓库。

在这里插入图片描述

  • 查看历史版本 git reflog
    在这里插入图片描述
  • 切换历史版本 git reset --hard 【版本索引】
    在这里插入图片描述此时我们回退到了第一个版本,第一个版本是不存在Demo2.txt文件的,我们查看,发现确实没有Demo2.txt文件。
    在这里插入图片描述

创建分支、合并分支、解决分支冲突

  • 查看分支信息 git branch -v
    在这里插入图片描述
    代表目前该仓库有两个分支,master前面的 * 表示当前正位于master分支

  • 创建分支 git branch 【分支名】
    例如 git branch branch01,我刚才创建了branch01分支,注意看,branch01的分支的历史版本和master分支的历史版本一样。

此时我在master分支创建Demo3.txt,并写入内容提交至本地仓库
在这里插入图片描述在这里插入图片描述

  • 切换分支 git checkout 【分支名】
    git checkout branch01 ,切换到branch01分支
    在这里插入图片描述
    branch01分支修改了Demo3.txt,并提交到本地仓库。

在这里插入图片描述

我们切换回master分支

  • 合并分支 git merge 【分支名】

我们切回到master分之后将两个分支的内容进行合并,但是此时由于我们master分支和branch01分支都在Demo3.txt的第一行修改了文件,所以就会产生了冲突。

git终端告诉我们Demo3.txt发生了冲突。
在这里插入图片描述我们查看Demo3.txt文件

在这里插入图片描述此时我们手动处理完冲突,然后并重新将Demo3.txt文件提交至本地仓库,但此时提交时会报错。

在这里插入图片描述提示 cannot do a partial commit during a merge.无法在合并期间执行部分提交。
注意:在处理完冲突后提交不能带有文件名

在这里插入图片描述
此时我们就解决好了合并分支冲突。

不同版本历史仓库合并

  • 正常的操作应是用IDEA创建项目时选择 Import from Version Control,输入项目http地址

在这里插入图片描述
此时我么新建文件,然后提交是可以成功的。

在这里插入图片描述

  • 使用IDEA重新新建一个本地项目。

在这里插入图片描述此时我们将gitdemo这个文件夹作为一个git仓库

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

给这个仓库新建一个要推送的远程库的位置,填写我们刚才创建的那个仓库位置即可。
在这里插入图片描述

当我们要推送的时候,会出现这个错误,因为这两个仓库目前没有关系,历史版本也不同,所以推送不上。

执行 git pull origin master --allow-unrelated-histories先将远程库的代码拉拉取下来做一个合并,然后再推送。

再次执行 git push origin master即可。

在这里插入图片描述

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值