为什么有时候切换分支看起来没有效果?看起来还自动merge了?

初学git,用命令

git branch

*   master

git checkout -b aa, 增加文件m

git checkout master

ls

出现了m文件,我以为应该没有的。很奇怪的现象。

然后,

git branch --merged

* master

   aa

看起来好像两个分支自动merge了一样。

仔细找了找原因,原来是我理解错误。

在git中分支实际上就是个指针,指向一个commit,在master分支时,新建一个分支aa,这个分支会指向master指向的commit,这里假设它是37de3889好了。而修改工作目录后,没有做commit,所以aa依然指向37de3889,而master也是指向37de3889。所以在git看来这俩指针一样的,就是merge了。

如果在git checkout -bb aa, 增加文件m,之后接着做commit

git add .

git commit -m "your message"

那么会新产生一个commit,假设它是a222e87好了,这时候aa会指向a222e87,master依然指向原来的37de3889,这个时候git就发现他俩不是一样的,就是没有merge了。这个时候git checkout master,会看不到m文件,因为m文件被git纳入管理范围了,对master来说这个新的commit:a222e87在它的指针后面,它看不到,所以就看不到这个新增加的文件。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值