博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
git status将文件状态标为renamed问题探究
阅读量:6812 次
发布时间:2019-06-26

本文共 691 字,大约阅读时间需要 2 分钟。

问题描述

线上项目有一个小bug,我修改了xx.js中的一行代码解决了问题,然后webpack打包,准备提交代码。

git add .git status

这时候我发现,git status的输出为:

renamed:    xx.1.js -> xx.2.js

我发现这不太对啊:renamed虽然可以体现出来webpack打包的时候改掉文件名hash值这个重命名的过程,但不能体现我改了文件内容啊。

我觉得应该这样输出才对:

deleted:     xx.1.jsnew file:    xx.2.js

于是开始找答案,看为什么和我想的不一样。

问题解决

搜了一圈,最终有些收获,结论先行:

git把文件标为
renamed的意思是并不是很具体的指这个文件
重命名了。他是一个
泛指,这是一个种所谓
heuristic(启发式,不懂不懂)的用法。

关于这个问题没有找到足够的资料,但是通过我的测试,发现:

一个文件的改动的行数低于
总行数的50%的,并且进行
重命名操作就会出现这种被标为
renamed的情况

测试方法如下:

  1. a.txt,里面内容为0-99的数字,每个一行,共100行。
  2. 把这个文件做commit
  3. 重命名a.txt为b.txt
  4. 删除49行内容,然后做add操作,然后做git status操作
  5. 删除50行内容,然后做add操作,然后做git status操作
  6. 删除51行内容,然后做add操作,然后做git status操作

同时在找资料的时候我也尝试了下面两个链接里提到的方式,但是在我的版本(2.19.2.windows.1)都没有成功复现。

参考文档

转载地址:http://iazzl.baihongyu.com/

你可能感兴趣的文章
Google推出实时内容洞察工具 为用户提供表现最好的内容
查看>>
虚拟机故障与故障处理工具之指令篇
查看>>
iOS 基础知识学习目录索引
查看>>
My_Base_notes
查看>>
Node assert断言学习及mocha框架与travisCI初探
查看>>
大话转岗 PHP 开发小结
查看>>
React的状态管理
查看>>
寻找一种易于理解的一致性算法(扩展版)下
查看>>
MySQL - 高可用性:少宕机即高可用?
查看>>
php 生成唯一值
查看>>
2018电影票房分析-谁才是票房之王
查看>>
程序员可以干到多少岁?
查看>>
Storm系列(六)storm和kafka集成
查看>>
东南亚的招聘骗局,程序员请注意!
查看>>
Android 获得View宽高的几种方式
查看>>
iOS正则表达式
查看>>
关于javascript的this指向问题
查看>>
Promise的理解和用法
查看>>
java B2B2C Springboot电子商城系统-高可用的服务注册中心
查看>>
Dubbo的总体架构
查看>>