git的忽略机制导致文件的丢失的问题

在第一个commit中还有文件file,然后写gitignore忽略file文件夹,清空缓存,再把其他全部添加到暂存区.

此时再修改file文件夹和其他文件,并提交.如果此时checkout到第一commit,file文件夹的修改不就没了吗?

再checkout回第二个commit,发现file文件夹没了,这算不算bug,因为file文件已经不被跟踪了, git也不会给出任何警告,怎样避免这样的情况的发生.也可能发生再分支间的切换.

新人,确实没有什么C币....

git

2个回答

这个不能算作bug吧。对于你第一次commit是把file文件做了版本管理,你之后的commit修改了.gitignore文件,并清空缓存重新添加,这时候就是告诉Git,你不需要Git记住file文件之后的每一次更改,file文件的变化由你自己掌握。这时候你切换回第一次的commit,这时候,因为第一次commit对file文件由版本管理的记录,Git必须也有义务帮你把当前整个工作区的文件状态恢复为第一次commit的状态,这时候你之前对于file文件的修改就会被覆盖,从而让file文件丢失之前的更改。一般来说,如果要在之后的commit中修改.gitignore文件的配置,都会存在这个问题,这是没法避免的。

既然需要进行分支之间的切换,又需要文件保留,为什么又要把文件弄成忽略呢?

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
如何让svn支持git的.ignore文件,达到忽略文件的目的
如题:如何让svn支持git的.ignore文件,达到忽略文件的目的
git add 添加 删除的文件
使用情景:暂存区中有一些文件,一波操作后:删除了一些文件、更改了一些文件。 要求:这次提交只想提交删除的文件,其他不提交,有没有快捷方式?
服务器上的一个木子目录下的.git文件夹里面的文件被删光了,怎么恢复
服务器上的一个木子目录下的.git文件夹里面的文件被删光了,怎么恢复? 接手别人的代码,要改需求
git如何把一台电脑上的提交迁移到另一个电脑上?
假设两台电脑都不可以联网,其中pc1的git仓库进行了若干次提交,pc2的git仓库还是一段时间之前的状态。 如果我想让pc2和pc1的git仓库保持同步,现在能想到的办法就是把pc1的git仓库打包压缩,然后拷贝到pc2上进行覆盖。这样看起来很傻,因为pc1和pc2的git仓库并没有差别非常大,完整地拷贝过程相当于在复制很多重复的数据。 想问下,是否有什么更为简便的方法,可以直接快速地实现pc2同步pc1?
git pull更新指定文件,但是不删除未指定的本地文件
比如我有6个文件放在同一个git仓库进行管理,其中3个文件只进行更新,另外3个只进行提交;但是现在更新的时候试了两种方法都有问题 方法一:我用git pull 加上sparse-checkout指定更新那3个文件,当我在git仓库中第一次修改文件的时候,无论是哪个文件,那3个指定更新的文件是被git库里面的覆盖更新了,但是未指定更新的那3个文件在本地就被删除了,在git库里面还在; 方法二:使用git checkout 分支 filename这种方式,如果在git仓库添加文件是会更新到本地仓库,但是如果删除文件就不会更新到本地仓库,本地的文件不会被删掉 求各位大神,走过路过,不要飘过,非常急啊
用gitblit搭建的git服务器,怎么实现文件的权限设置?
用gitblit搭建的git服务器,怎么实现文件的权限设置?比如a文件b用户可以看到c不能看到
git比较两个分支的文件
本人在git上有两个远程分支,一个是uat,一个是master,每次uat测试通过之后,就会把uat分支的代码递交到master,使两者保持同步。因为有一段日子没有更新版本了,现在想比较一下两个分支的文件差异,没有想到有一大堆不一样。但从文件实际内容上来看,却是一样的。用的是git diff uat master --stat命令,不知道有diff命令比较是比较的什么东西,我只想比较两个分支里的文件代码内容是否一样就可以了,各位有什么好办法没有。谢谢!
SmartGit如何使用git svn功能,使git和svn协同工作
工作中有一个需求是git和svn一块用,可以将git的代码同步到远程svn服务器
git问题:怎样在保留远程文件A的同时,不被本地文件A更新呢?
我用GIT管理的thinkphp项目,希望在保留远程config.php文件的同时,不被本地config.php文件更新. 我在本地项目的.gitignore文件内容如下: Home/Conf/config.php Admin/Conf/config.php Runtime/ .idea/ 生成这个.gitignore文件后,我先是: git rm -- cached . git add . git commit 然后修改本地程序后,最后push到远程。 结果是,它虽然能够忽略本地的config.php文件,但也删除了我远程的config.php。 怎样在保留远程config.php文件的同时,不被本地config.php文件更新呢?
升级完git 2.20 brew update失败
前几天brew 提示git升级,结果升级之后brew 一直是超时
git的submit的一些问题
正在学习git 版本:2.8 发现commit的一些问题,不知道是否我理解的有问题。 不正常的commit提交: ![图片说明](https://img-ask.csdn.net/upload/201604/08/1460095052_571391.png) 修改了一个文件,并且提示红色的,按理说,我应该先add上去,然后再commit, 那么我直接commit了, ![图片说明](https://img-ask.csdn.net/upload/201604/08/1460095120_269316.png) 最终,发现git status提示是clean的,而且各种git diff都提示没有问题。 commit不是只负责提交缓存区到版本区么,怎么还自动处理工作区的文件了,我也没有使用commit -a 的参数啊。 各位大神解释下?或者我哪个地方理解的有问题了?
Git 太久没有提交导致的问题
Counting objects: 1189, done. Delta compression using up to 4 threads. Compressing objects: 100% (1076/1076), done. Writing objects: 100% (1189/1189), 104.87 MiB | 6.02 MiB/s, done. Total 1189 (delta 872), reused 27 (delta 1) error: RPC failed; HTTP 502 curl 22 The requested URL returned error: 502 Bad Gateway fatal: The remote end hung up unexpectedly fatal: The remote end hung up unexpectedly Everything up-to-date 就这样一直卡着不会动,全局我都设置成了 git config --global http.postBuffer 9524288000
linux下git链接码云账号密码问题。
前提: 1.我已在linux下安装好git,并且ssh-keygen 生成秘钥配置在我的码云中。 2.已将代码通过git clone -b 分支 http://git用户名:git密码@xxxxxxxxx.git 的方式拉取到linux上。 3.![图片说明](https://img-ask.csdn.net/upload/201912/11/1576028264_276073.jpg) 我编写脚本拉取代码打包部署。因为第二点,这里的git pull是不需要输入账号密码的。 问题: 1.我想知道,我这个拉取代码是第一步起作用还是第二步,他的原理是啥。如果是第二步它的账号密码存在哪了。 2.如果我之后想改变这个用户名密码(码云账号密码)怎么改。 注:看了网上许多文章更改linux下git的账号密码,比如.git-credentials 想了解.git-credentials和第二步有啥不同。 请了解的大神告知,不胜感谢。
idea 19.3.2 版本 git 的 update info 记录 变成树桩图就像log一样 之前的版本是可以直观的看到本次更新下来多少代码
idea 19.3.2 版本 git 的 update info 记录 变成树桩图就像log一样 之前的版本是可以直观的看到本次更新下来多少代码 这是之前的 ![图片说明](https://img-ask.csdn.net/upload/202002/04/1580801569_326677.jpg) 这是更新完3.2版本的 ![图片说明](https://img-ask.csdn.net/upload/202002/04/1580801610_559255.jpg) 请问如何设置能变回以前的浏览方式,如果不能,就只能退回19.2版本了
Windows配置git服务器,git时找不到文件
最近用winows10配了一个git服务器,用的是copssh。之前已经配置成功了,然而手贱删了一部分入站端口,导致服务器连不上。 重装copssh之后,可以实现连接ssh,但不能git , 但单独使用git 克隆github上的项目是可以的。 我感觉第一次配的时候好像也有这个问题,但那时候没把处理这个问题的文档资料保存下来,现在不知道怎么处理了。 提示的错误如图所示,保证文件存在,且为纯版本库,ssh连接正常,各位大神看看,这个是个什么问题?![图片](https://img-ask.csdn.net/upload/201608/27/1472266805_515144.png)![图片](https://img-ask.csdn.net/upload/201608/27/1472266813_469317.jpg)
关于git推送的问题,新手求教
我有这样一种场景: 我先把我本地的代码部署到了服务器上了,没有git关联。 后来我把本地的代码推送到了git上做了一个管理仓库。那我服务器上的代码 如何跟git上面的分支做关联? 具体要如何操作,求教各位大神
springCloud config配置中心在cenots7上启动不能获取配置??
本人学习springCloud的config配置中心时,在本地启动可以在basedir路径下下载在git上的配置文件。 然后我将项目打包,放在了阿里云服务器上,可以成功启动但是不会在basedir下下载配置,其他服务也无法正常使用。 求解???? 附上配置 ![图片说明](https://img-ask.csdn.net/upload/202002/16/1581832030_949472.png)
git 和repo的基础问题
我在一个文件夹下安装了git,那么在其他的文件夹下可以用git的命令吗/ repo start 建立分支这个命令,建好分支以后怎样让它指向所要用的项目
GIT:怎样在保留远程文件A的同时,不被本地文件A更新呢?
我用GIT管理的thinkphp项目,希望在保留远程config.php文件的同时,不被本地config.php文件更新. 我在本地项目的.gitignore文件内容如下: Home/Conf/config.php Admin/Conf/config.php Runtime/ .idea/ 生成这个.gitignore文件后,我先是: git rm -- cached . git add . git commit 然后修改本地程序后,最后push到远程。 结果是,它虽然能够忽略本地的config.php文件,但也删除了我远程的config.php。 怎样在保留远程config.php文件的同时,不被本地config.php文件更新呢?
终于明白阿里百度这样的大公司,为什么面试经常拿ThreadLocal考验求职者了
点击上面↑「爱开发」关注我们每晚10点,捕获技术思考和创业资源洞察什么是ThreadLocalThreadLocal是一个本地线程副本变量工具类,各个线程都拥有一份线程私...
《奇巧淫技》系列-python!!每天早上八点自动发送天气预报邮件到QQ邮箱
将代码部署服务器,每日早上定时获取到天气数据,并发送到邮箱。 也可以说是一个小人工智障。 思路可以运用在不同地方,主要介绍的是思路。
加快推动区块链技术和产业创新发展,2019可信区块链峰会在京召开
11月8日,由中国信息通信研究院、中国通信标准化协会、中国互联网协会、可信区块链推进计划联合主办,科技行者协办的2019可信区块链峰会将在北京悠唐皇冠假日酒店开幕。   区块链技术被认为是继蒸汽机、电力、互联网之后,下一代颠覆性的核心技术。如果说蒸汽机释放了人类的生产力,电力解决了人类基本的生活需求,互联网彻底改变了信息传递的方式,区块链作为构造信任的技术有重要的价值。   1...
阿里面试官问我:如何设计秒杀系统?我的回答让他比起大拇指
你知道的越多,你不知道的越多 点赞再看,养成习惯 GitHub上已经开源 https://github.com/JavaFamily 有一线大厂面试点脑图和个人联系方式,欢迎Star和指教 前言 Redis在互联网技术存储方面使用如此广泛,几乎所有的后端技术面试官都要在Redis的使用和原理方面对小伙伴们进行360°的刁难。 作为一个在互联网公司面一次拿一次Offer的面霸,打败了...
C语言魔塔游戏
很早就很想写这个,今天终于写完了。 游戏截图: 编译环境: VS2017 游戏需要一些图片,如果有想要的或者对游戏有什么看法的可以加我的QQ 2985486630 讨论,如果暂时没有回应,可以在博客下方留言,到时候我会看到。 下面我来介绍一下游戏的主要功能和实现方式 首先是玩家的定义,使用结构体,这个名字是可以自己改变的 struct gamerole { char n...
面试官问我:什么是消息队列?什么场景需要他?用了会出现什么问题?
你知道的越多,你不知道的越多 点赞再看,养成习惯 GitHub上已经开源 https://github.com/JavaFamily 有一线大厂面试点脑图、个人联系方式和人才交流群,欢迎Star和完善 前言 消息队列在互联网技术存储方面使用如此广泛,几乎所有的后端技术面试官都要在消息队列的使用和原理方面对小伙伴们进行360°的刁难。 作为一个在互联网公司面一次拿一次Offer的面霸...
Android性能优化(4):UI渲染机制以及优化
文章目录1. 渲染机制分析1.1 渲染机制1.2 卡顿现象1.3 内存抖动2. 渲染优化方式2.1 过度绘制优化2.1.1 Show GPU overdraw2.1.2 Profile GPU Rendering2.2 卡顿优化2.2.1 SysTrace2.2.2 TraceView 在从Android 6.0源码的角度剖析View的绘制原理一文中,我们了解到View的绘制流程有三个步骤,即m...
微服务中的Kafka与Micronaut
今天,我们将通过Apache Kafka主题构建一些彼此异步通信的微服务。我们使用Micronaut框架,它为与Kafka集成提供专门的库。让我们简要介绍一下示例系统的体系结构。我们有四个微型服务:订单服务,行程服务,司机服务和乘客服务。这些应用程序的实现非常简单。它们都有内存存储,并连接到同一个Kafka实例。 我们系统的主要目标是为客户安排行程。订单服务应用程序还充当网关。它接收来自客户的请求...
致 Python 初学者们!
作者| 许向武 责编 | 屠敏 出品 | CSDN 博客 前言 在 Python 进阶的过程中,相信很多同学应该大致上学习了很多 Python 的基础知识,也正在努力成长。在此期间,一定遇到了很多的困惑,对未来的学习方向感到迷茫。我非常理解你们所面临的处境。我从2007年开始接触 Python 这门编程语言,从2009年开始单一使用 Python 应对所有的开发工作,直至今...
究竟你适不适合买Mac?
我清晰的记得,刚买的macbook pro回到家,开机后第一件事情,就是上了淘宝网,花了500元钱,找了一个上门维修电脑的师傅,上门给我装了一个windows系统。。。。。。 表砍我。。。 当时买mac的初衷,只是想要个固态硬盘的笔记本,用来运行一些复杂的扑克软件。而看了当时所有的SSD笔记本后,最终决定,还是买个好(xiong)看(da)的。 已经有好几个朋友问我mba怎么样了,所以今天尽量客观...
程序员一般通过什么途径接私活?
二哥,你好,我想知道一般程序猿都如何接私活,我也想接,能告诉我一些方法吗? 上面是一个读者“烦不烦”问我的一个问题。其实不止是“烦不烦”,还有很多读者问过我类似这样的问题。 我接的私活不算多,挣到的钱也没有多少,加起来不到 20W。说实话,这个数目说出来我是有点心虚的,毕竟太少了,大家轻喷。但我想,恰好配得上“一般程序员”这个称号啊。毕竟苍蝇再小也是肉,我也算是有经验的人了。 唾弃接私活、做外...
字节跳动面试官这样问消息队列:分布式事务、重复消费、顺序消费,我整理了一下
你知道的越多,你不知道的越多 点赞再看,养成习惯 GitHub上已经开源 https://github.com/JavaFamily 有一线大厂面试点脑图、个人联系方式和人才交流群,欢迎Star和完善 前言 消息队列在互联网技术存储方面使用如此广泛,几乎所有的后端技术面试官都要在消息队列的使用和原理方面对小伙伴们进行360°的刁难。 作为一个在互联网公司面一次拿一次Offer的面霸...
Python爬虫爬取淘宝,京东商品信息
小编是一个理科生,不善长说一些废话。简单介绍下原理然后直接上代码。 使用的工具(Python+pycharm2019.3+selenium+xpath+chromedriver)其中要使用pycharm也可以私聊我selenium是一个框架可以通过pip下载 pip installselenium -ihttps://pypi.tuna.tsinghua.edu.cn/simple/ ...
阿里程序员写了一个新手都写不出的低级bug,被骂惨了。
这种新手都不会范的错,居然被一个工作好几年的小伙子写出来,差点被当场开除了。
Java工作4年来应聘要16K最后没要,细节如下。。。
前奏: 今天2B哥和大家分享一位前几天面试的一位应聘者,工作4年26岁,统招本科。 以下就是他的简历和面试情况。 基本情况: 专业技能: 1、 熟悉Sping了解SpringMVC、SpringBoot、Mybatis等框架、了解SpringCloud微服务 2、 熟悉常用项目管理工具:SVN、GIT、MAVEN、Jenkins 3、 熟悉Nginx、tomca...
SpringBoot2.x系列教程(三十六)SpringBoot之Tomcat配置
Spring Boot默认内嵌的Tomcat为Servlet容器,关于Tomcat的所有属性都在ServerProperties配置类中。同时,也可以实现一些接口来自定义内嵌Servlet容器和内嵌Tomcat等的配置。 关于此配置,网络上有大量的资料,但都是基于SpringBoot1.5.x版本,并不适合当前最新版本。本文将带大家了解一下最新版本的使用。 ServerProperties的部分源...
Python绘图,圣诞树,花,爱心 | Turtle篇
每周每日,分享Python实战代码,入门资料,进阶资料,基础语法,爬虫,数据分析,web网站,机器学习,深度学习等等。 公众号回复【进群】沟通交流吧,QQ扫码进群学习吧 微信群 QQ群 1.画圣诞树 import turtle screen = turtle.Screen() screen.setup(800,600) circle = turtle.Turtle()...
作为一个程序员,CPU的这些硬核知识你必须会!
CPU对每个程序员来说,是个既熟悉又陌生的东西? 如果你只知道CPU是中央处理器的话,那可能对你并没有什么用,那么作为程序员的我们,必须要搞懂的就是CPU这家伙是如何运行的,尤其要搞懂它里面的寄存器是怎么一回事,因为这将让你从底层明白程序的运行机制。 随我一起,来好好认识下CPU这货吧 把CPU掰开来看 对于CPU来说,我们首先就要搞明白它是怎么回事,也就是它的内部构造,当然,CPU那么牛的一个东...
破14亿,Python分析我国存在哪些人口危机!
一、背景 二、爬取数据 三、数据分析 1、总人口 2、男女人口比例 3、人口城镇化 4、人口增长率 5、人口老化(抚养比) 6、各省人口 7、世界人口 四、遇到的问题 遇到的问题 1、数据分页,需要获取从1949-2018年数据,观察到有近20年参数:LAST20,由此推测获取近70年的参数可设置为:LAST70 2、2019年数据没有放上去,可以手动添加上去 3、将数据进行 行列转换 4、列名...
听说想当黑客的都玩过这个Monyer游戏(1~14攻略)
第零关 进入传送门开始第0关(游戏链接) 请点击链接进入第1关: 连接在左边→ ←连接在右边 看不到啊。。。。(只能看到一堆大佬做完的留名,也能看到菜鸡的我,在后面~~) 直接fn+f12吧 <span>连接在左边→</span> <a href="first.php"></a> <span>←连接在右边</span> o...
在家远程办公效率低?那你一定要收好这个「在家办公」神器!
相信大家都已经收到国务院延长春节假期的消息,接下来,在家远程办公可能将会持续一段时间。 但是问题来了。远程办公不是人在电脑前就当坐班了,相反,对于沟通效率,文件协作,以及信息安全都有着极高的要求。有着非常多的挑战,比如: 1在异地互相不见面的会议上,如何提高沟通效率? 2文件之间的来往反馈如何做到及时性?如何保证信息安全? 3如何规划安排每天工作,以及如何进行成果验收? ...... ...
作为一个程序员,内存和磁盘的这些事情,你不得不知道啊!!!
截止目前,我已经分享了如下几篇文章: 一个程序在计算机中是如何运行的?超级干货!!! 作为一个程序员,CPU的这些硬核知识你必须会! 作为一个程序员,内存的这些硬核知识你必须懂! 这些知识可以说是我们之前都不太重视的基础知识,可能大家在上大学的时候都学习过了,但是嘞,当时由于老师讲解的没那么有趣,又加上这些知识本身就比较枯燥,所以嘞,大家当初几乎等于没学。 再说啦,学习这些,也看不出来有什么用啊!...
这个世界上人真的分三六九等,你信吗?
偶然间,在知乎上看到一个问题 一时间,勾起了我深深的回忆。 以前在厂里打过两次工,做过家教,干过辅导班,做过中介。零下几度的晚上,贴过广告,满脸、满手地长冻疮。 再回首那段岁月,虽然苦,但让我学会了坚持和忍耐。让我明白了,在这个世界上,无论环境多么的恶劣,只要心存希望,星星之火,亦可燎原。 下文是原回答,希望能对你能有所启发。 如果我说,这个世界上人真的分三六九等,...
2020年全新Java学习路线图,含配套视频,学完即为中级Java程序员!!
新的一年来临,突如其来的疫情打破了平静的生活! 在家的你是否很无聊,如果无聊就来学习吧! 世上只有一种投资只赚不赔,那就是学习!!! 传智播客于2020年升级了Java学习线路图,硬核升级,免费放送! 学完你就是中级程序员,能更快一步找到工作! 一、Java基础 JavaSE基础是Java中级程序员的起点,是帮助你从小白到懂得编程的必经之路。 在Java基础板块中有6个子模块的学...
B 站上有哪些很好的学习资源?
哇说起B站,在小九眼里就是宝藏般的存在,放年假宅在家时一天刷6、7个小时不在话下,更别提今年的跨年晚会,我简直是跪着看完的!! 最早大家聚在在B站是为了追番,再后来我在上面刷欧美新歌和漂亮小姐姐的舞蹈视频,最近两年我和周围的朋友们已经把B站当作学习教室了,而且学习成本还免费,真是个励志的好平台ヽ(.◕ฺˇд ˇ◕ฺ;)ノ 下面我们就来盘点一下B站上优质的学习资源: 综合类 Oeasy: 综合...
爬取薅羊毛网站百度云资源
这是疫情期间无聊做的爬虫, 去获取暂时用不上的教程 import threading import time import pandas as pd import requests import re from threading import Thread, Lock # import urllib.request as request # req=urllib.request.Requ...
如何优雅地打印一个Java对象?
你好呀,我是沉默王二,一个和黄家驹一样身高,和刘德华一样颜值的程序员。虽然已经写了十多年的 Java 代码,但仍然觉得自己是个菜鸟(请允许我惭愧一下)。 在一个月黑风高的夜晚,我思前想后,觉得再也不能这么蹉跎下去了。于是痛下决心,准备通过输出的方式倒逼输入,以此来修炼自己的内功,从而进阶成为一名真正意义上的大神。与此同时,希望这些文章能够帮助到更多的读者,让大家在学习的路上不再寂寞、空虚和冷。 ...
雷火神山直播超两亿,Web播放器事件监听是怎么实现的?
Web播放器解决了在手机浏览器和PC浏览器上播放音视频数据的问题,让视音频内容可以不依赖用户安装App,就能进行播放以及在社交平台进行传播。在视频业务大数据平台中,播放数据的统计分析非常重要,所以Web播放器在使用过程中,需要对其内部的数据进行收集并上报至服务端,此时,就需要对发生在其内部的一些播放行为进行事件监听。 那么Web播放器事件监听是怎么实现的呢? 01 监听事件明细表 名...
3万字总结,Mysql优化之精髓
本文知识点较多,篇幅较长,请耐心学习 MySQL已经成为时下关系型数据库产品的中坚力量,备受互联网大厂的青睐,出门面试想进BAT,想拿高工资,不会点MySQL优化知识,拿offer的成功率会大大下降。 为什么要优化 系统的吞吐量瓶颈往往出现在数据库的访问速度上 随着应用程序的运行,数据库的中的数据会越来越多,处理时间会相应变慢 数据是存放在磁盘上的,读写速度无法和内存相比 如何优化 设计...
HTML5适合的情人节礼物有纪念日期功能
前言 利用HTML5,css,js实现爱心树 以及 纪念日期的功能 网页有播放音乐功能 以及打字倾诉感情的画面,非常适合情人节送给女朋友 具体的HTML代码 具体只要修改代码里面的男某某和女某某 文字段也可自行修改,还有代码下半部分的JS代码需要修改一下起始日期 注意月份为0~11月 也就是月份需要减一。 当然只有一部分HTML和JS代码不够运行的,文章最下面还附加了完整代码的下载地址 <!...
相关热词 c# 压缩图片好麻烦 c#计算数组中的平均值 c#获取路由参数 c#日期精确到分钟 c#自定义异常必须继承 c#查表并返回值 c# 动态 表达式树 c# 监控方法耗时 c# listbox c#chart显示滚动条
立即提问