windows下git显示文件被修改,实际没有改动的问题解决办法

windows下git显示文件被修改,实际没有改动的问题解决办法

不少开发者可能遇到过这个问题:从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可能会不工作,尤其是文件中出现中文字符后有换行符时。

解决方案

1.禁用git的自动换行功能:
在本地路径C:\ Users\ [用户名] \ .gitconfig下修改git配置[core],如果没有就直接添加上去:

[core]
autocrlf = false
filemode = false
safecrlf = true

git bash命令行也可以修改,最终也是修改.gitconfig配置文件:
分别执行:

git config --global core.autocrlf false
git config --global core.filemode false
git config --global core.safecrlf true

2.配置IDE开发环境,将它的换行格式指定为LF,以android studio为例:
windows下git显示文件被修改,实际没有改动的问题解决办法

原文:https://blog.csdn.net/whsdu929/article/details/52490188

方法二:

当我们pull完代码时进行修改,修改后提交代码时会发现一些文件并未修改,但显示有差异,而且通过git status查看时是Untracked file如下:

$ git status
On branch master
Your branch is behind ‘origin/master’ by 27 commits, and can be fast-forwarded.
  (use “git pull” to update your local branch)

Untracked files:
  (use “git add <file>…” to include in what will be committed)

        model/src/main/java/

nothing added to commit but untracked files present (use “git add” to track)

 

如果忽略这些问题有时代码可以正常的pull和commit,但有时会导致我们pull代码失败,并提示:

error: The following untracked working tree files would be overwritten by merge

出错的文件正是那些不是我们修改的文件,这时候可以用如下方式进行处理:

1、git fetch origin master

把远端的代码拉倒本地,并把指针放到FETCH_HEAD中

$ git fetch origin master
connected to center BJ
From ssh:****
 * branch            master     -> FETCH_HEAD
Warning: cannot log into influxdb

2、git reset –hard FETCH_HEAD

把本地的代码指针切换到刚刚拉下来的那个指针上;

 

3、git push origin master

把本地的代码推送到远端,其实即使不推送也没问题,因为本地代码跟远端已经一致了;

$ git push origin master
connected to center BJ
Warning: cannot log into influxdb
Everything up-to-date

 

4、git status

再次查看发现那些文件的差异已经没有了

$ git status
On branch master
Your branch is up-to-date with ‘origin/master’.

nothing to commit, working directory clean

5、后面可以继续执行其他操作了

原文:https://blog.csdn.net/weixin_38178584/article/details/81298004

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/112449.html原文链接:https://javaforall.net

(0)
上一篇 2021年11月7日 下午3:00
下一篇 2021年11月7日 下午4:00


相关推荐

  • 家谱树项目

    家谱树项目FamilyTree c ifndefFAMILY C defineFAMILY C include FamilyTree h include include include includevoidI Tree structBinNod tree tree NULL structBinNod S

    2026年3月19日
    3
  • 5g 网络切片 边缘计算_5g网络切片技术前景

    5g 网络切片 边缘计算_5g网络切片技术前景紧接上文接入网RANRAN切片提供了基于切片ID的AMF/UPF选择,并提供了相对静态的资源控制和优先级控制。此外,RAN通过RIC(RANIntelligentControl,通过E2接口连接gNB)实现了针对动态资源调度和优先级控制等的实时闭环控制。关于RAN切片的基本机构可参照下图优先级控制在未适用网络切片前,显然,gNB并不能针对UE的不同服务做不同的优先级控制。在适用了5G的网络切片后,运营商就能就能通过不同的网络切片在无线侧调度不同的优先级(这是显而易见的,哈哈)。譬如UE1用高优

    2026年4月14日
    5
  • js中数组求和_多个数组对应项求和

    js中数组求和_多个数组对应项求和js数组求和的5种方法题目描述计算给定数组arr中所有元素的总和输入描述:数组中的元素均为Number类型输入例子:sum([1,2,3,4])输出例子:101、不考虑算法复杂度,用递归做:functionsum(arr){varlen=arr.length;if(len==0){return0;}elseif(len==1){returnarr[0

    2026年4月13日
    4
  • php stripslashes 去除反斜线

    php stripslashes 去除反斜线stripslashes 可以去除反斜线 准确的说是去掉一个反斜线 因为如果是两个反斜线的话 stripslashes 会把两个反斜线替换成一个 引用 php 手册的例子 php str IsyournameO reilly 输出 IsyournameO reilly echostripsla str

    2026年3月26日
    1
  • JavaScript:绝对值和三种取整方法(floor、round、ceil)详解

    JavaScript:绝对值和三种取整方法(floor、round、ceil)详解文章目录前言前言 script 1 绝对值方法 console log Math abs 1 console log Math abs 1 console log Math abs 1 隐式转换会把字符串型 1 转换为数字型 console log Math abs pink NaN 2 三个取整方法 1 Mat script

    2026年3月19日
    2
  • 安卓反编译_apk可以反编译吗

    安卓反编译_apk可以反编译吗本帖最后由好奇害死猫咪啊于2017-5-621:48编辑本教程为长期更新贴,有问题请及时反馈。如有更新请恕不另行通知。【前言】闲来无事水一贴。。。今天写个教程吧,反编译SystemUI实现状态栏时钟居中。其实说实话本来对华为靠右边的时间不怎么介意的,可一位朋友说什么也想换成类似iPhone的居中式,甚至不惜去刷XP框架,装重力工具箱。。当然了,结果大家可能已经想到了,首先是重力工…

    2026年1月20日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号