GIT关联并同步远程仓库和本地仓库

一、创建远程仓库

这是初始状态,远程仓库已经创建了一些文件了

 

二、创建本地仓库

先在本地创建一个空文件夹(可以作为工作空间),然后cmd进入这个文件夹执行git init

847ba107096dc4ac8c762695fde90a50b62.jpg

接着,可以在这个工作空间中创建若干项目,比如我用IDEA创建一个C++项目,

注意最好在工作空间的子目录中创建项目,这样就能创建多个项目互不干扰,又能在同一个git仓库中管理

比如我创建一个project1项目,项目根目录为 C:\03_WorkSpace\test_ws\project1,

在新建项目中新建一些文件,比如我创建了一个跟远程仓库同名的文件 README.md,这样能演示同步问题

6ac67b1abe560dcb7cfb06ebff01235e63f.jpg

三、修改git管理的本地文件版本状态

先查看一下目前本地仓库情况,

b7fa773a7f492de116609cbe8c31b10c48d.jpg

上图中README.md文件状态有两项,一项是changes to be committed,因为前面新建了这个文件还没提交,此时可以提交。

另一项是not staged状态,因为新建这个文件后修改了内容,可以使用git add转为staged以便提交,或者用git checkout放弃修改。若直接提交这个文件的话,修改的内容将不会提交。

最下面是还没有纳入版本库管理的文件,可以用git add加入版本管理。

关于GIT文件的状态转换,可参考 https://git-scm.com/book/zh/v2/Git-%E5%9F%BA%E7%A1%80-%E8%AE%B0%E5%BD%95%E6%AF%8F%E6%AC%A1%E6%9B%B4%E6%96%B0%E5%88%B0%E4%BB%93%E5%BA%93

Git ä¸æ件çå½å¨æå¾ã

现在先将README.md和main.cpp变为staged状态。

416959fa754f79e2bcd2878bb886c686b45.jpg

四、提交修改到本地仓库

d60b950deac956a9284ee64d8891e9c66fd.jpg

五、关联本地和远程仓库

7574c96c9c23627d3aed70671f468cb4073.jpg

六、合并本地仓库和远程仓库

因为本地和远程分别独立建了仓库,两个库并不同步

git pull命令可以同步远程和本地,注意git pull = git fetch + git merge 并自动解决冲突,

但是会隐藏许多细节,造成一些更大的错误,所以不要直接使用这个命令,最好分步骤手动同步。

004654484d79ae13d670c60de405a385f30.jpg

七、推送并解决冲突

直接冲突会说远程和本地不同步

f50d89f329e8826930e0f44d16773d031b8.jpg

再pull一次

bfb0d46e0b38973d01dbd27af09b25cc6f0.jpg

报错 fatal: refusing to merge unrelated histories

按网友做法,pull时加参数 --allow-unrelated-histories , pull成功

e5b92bd786760a6349ea3de484ea48827fa.jpg

再push一次

443b92b12977eecae698196389872c70c07.jpg

成功了。

注意push过程也有可能出现HEAD detached from XXX错误,

用以下办法解决,参考自 https://blog.csdn.net/u011240877/article/details/76273335

 

转载于:https://my.oschina.net/u/3300976/blog/3022171

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值