前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >git文件无修改diff无变更居然有许多文件需要提交—被修改

git文件无修改diff无变更居然有许多文件需要提交—被修改

原创
作者头像
周陆军博客
发布2023-06-06 11:40:11
2.1K0
发布2023-06-06 11:40:11
举报
文章被收录于专栏:前端博客前端博客

git显示文件被修改,实际没有改动,这是什么原因呢?

  • git diff [filename]  检测不到任何改动
  • git diff --cached也给了我空白输出。
  • git log也没有输出

其实有很多种请客。git status可能有一些不同的原因,但git diff可能没有。

  • 文件的模式(权限位)已更改——例如,从777更改为700。
  • 换行样式从crlf(dos)改为lf(unix)

第一种:https://www.cnblogs.com/lxwphp/p/10632353.html

不同系统换行符问题

从git上拉取服务端代码,然后只修改了一处地方,准备提交时,用diff软件查看,却发现整个文件都被修改了。这是git自动转换换行符导致的问题。

不同操作系统使用的换行符是不一样的。

  • Unix/Linux使用的是LF,
  • Mac后期也采用了LF
  • Windows一直使用CRLF【回车(CR, ASCII 13, \r) 换行(LF, ASCII 10, \n)】作为换行符。

git入库的代码采用的是LF格式,它考虑到了跨平台协作的场景,提供了“换行符自动转换”的功能: 如果在Windows下安装git,在拉取文件时,会自动将LF换行符替换为CRLF;在提交时,又会将CRLF转回LF。但是这个转换是有问题的:有时提交时,CRLF转回LF可能会不工作,尤其是文件中出现中文字符后有换行符时。

解决方案

禁用git的自动换行功能:

bash命令解决

代码语言:javascript
复制
git config --global core.autocrlf false
git config --global core.filemode false
git config --global core.safecrlf true

配置IDE开发环境,将它的换行格式指定为LF,以android studio为例:

2.png
2.png

系统权限修改导致的修改

git互联网文件权限

代码语言:javascript
复制
git config core.filemode false

参考文章:

Git状态显示更改的文件,但Git Diff不显示 https://www.codenong.com/14564946/

转载本站文章《git文件无修改diff无变更居然有许多文件需要提交—被修改》, 请注明出处:https://www.zhoulujun.cn/html/tools/VCS/git/8739.html

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 不同系统换行符问题
    • 禁用git的自动换行功能:
    • 系统权限修改导致的修改
    领券
    问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档