Git 代码防丢指南,再也不怕丢失代码了!
上一篇:深夜看了张一鸣的微博,让我越想越后怕
作者:joymufeng
来源:https://my.oschina.net/joymufeng/blog/3005221
我们在日常使用Git的过程中经常会发生一些意外情况,如果处理不当,则可能会出现代码丢失的假象。本文将针对IDEA
&Git
日常开发中的一些场景,为你层层拨开迷雾,解析常见的错误及其发生原因,让你从此不再惧怕代码冲突或丢失问题。
为简化问题,本文假设所有团队成员均在同一分支上开发。文中
更新操作
是指在IDEA
中单击菜单VCS
-Update Project...
。
1. 常见工作流程
通常当你早上到公司打开电脑,首先执行更新操作(单击IDEA
菜单VCS
-Update Project...
),然后开始愉快地编码。编码完成后通常要执行以下几个操作:
更新操作
创建本次提交
推送远程分支
1.1 更新操作
为了保证Git拥有一个简洁的提交历史,在提交之前需要先执行更新操作,即在IDEA中依次单击菜单VCS
-Update Project...
,或者按下Ctrl+T
,弹出如下窗口:
窗口左侧选择更新类型(Update Type):
Merge
:更新时执行合并操作。等价于执行git fetch && git merge
或者git pull --no-rebase
。Rebase
:更新时执行rebase
操作。等价于执行git fetch && git rebase
或者git pull --rebase
。Branch Default
:在.git/config
文件中指定不同分支的更新类型。
窗口右侧选择在更新前工作目录(Working Directory)的清理方式:
Using Stash
:使用git stash
储藏本地修改。Using Shelve
:使用IDEA内置的Shelve
功能储藏本地修改。
通常选择Merge
和Using Stash
即可,单击OK
后,IDEA执行步骤如下:
第1步:使用
git stash
储藏本地修改第2步:执行
git fetch && git merge
拉取远程分支并合并第3步:执行
git stash pop
恢复储藏
有些同学可能更习惯先创建本地提交,然后在执行更新操作,这样会导致Git自动生成一个合并提交,导致提交历史不够简洁。
1.2 创建本次提交
更新完成后,在IDEA中单击菜单VCS
-Commit...
创建本次提交。
1.3 推送远程分支
然后单击VCS
-Git
-Push...
推送至远程分支。
2. 常见问题分析
在上面的3步执行步骤中,第2步和第3步发生意外的风险最高,最常见的两种意外情况是冲突和文件占用,下面我们分别讨论。
2.1 合并远程分支冲突
如果在执行更新操作之前,你的本地分支已经创建过提交,并且尚未推送至远程分支,则在第2步执行git merge
时很可能会发生冲突。
此时关闭上面的冲突窗口,Version Control
工具窗口显示内容如下:
窗口右下角原本显示分支名称的位置变成了Merging master
,表示本地分支master
目前处于正在合并状态。单击左侧红框内Resolve
按钮可以再次调出处理冲突窗口。
基于IDEA的图形界面手动解决冲突后,IDEA会自动将该文件加入暂存区(加入暂存区即表示冲突解决完成),最后执行一次提交便可以完成冲突处理。另外,免费申请 IDEA 正版 License 教程,可以微信搜索互联网架构师在历史文章中搜索阅读。
2.2 恢复储藏冲突
在更新操作的第3步执行git stash pop
恢复储藏时,储藏内容可能与刚更新的内容发生冲突。
恢复储藏时发生的冲突跟上面的合并冲突稍微有些区别,首先是右下角的分支名称没有Merging
字样,另外会在右下角额外弹出一个小窗提示恢复储藏失败,并且告诉你不用担心,所有的修改都在stash
列表中,并没有丢失。查看stash
列表的方式为单击菜单VCS
-Git
-UnStash Changes...
:
选中列表最上面的条目,然后单击Apply Stash
,之前的修改就会重新回到工作目录。我们继续回到冲突问题,手动解决冲突后执行一次提交就可以了。如果在解决冲突过程中发生了误操作,可以右击Default Changelist
-Revert...
清空当前工作目录内容,重新执行一次Apply Stash
,然后重复解决冲突过程。
2.3 文件占用错误
在执行第2步git merge
时,可能会因为文件被占用导致执行失败。例如项目可能引入了一些jar文件,这些jar文件在本地已经被JVM动态加载了,如果有其它人更新了该jar文件并且推送到了远程分支,当你更新时便会遇到上述问题。
对于这种错误的解决方法很简单,首先解除文件的占用状态,例如终止本地JVM进程,然后再次点击VCS
-Update
。另外,JVM 系列面试题和答案全部整理好了,微信搜索互联网架构师,在后台发送:2T,可以在线阅读。
在执行第3步git stash pop
时,也会因为文件被占用导致执行失败。例如你更新了某个jar文件,当恢复储藏时可能因为该jar文件被占用导致恢复失败。
对于这种错误,你需要首先解除文件占用状态,然后手动执行unstash
操作。
3. 先提交还是先更新?是个问题!
3.1 先提交后更新导致的问题
3.1.1 发生冲突时难以处理
如果先提交,但是在更新时却发生了冲突,这就意味着你刚刚创建的提交其实是有问题的,通常是团队沟通或是分工出了问题,但是不管这么说,别人已经抢先一步push
了,你的提交便会被拒之门外。
即便是手动解决了冲突,这个提交保留在历史中也会成为隐患,如果有其他人reset
回这个提交继续工作,则在合并其它分支内容时发生冲突的概率会大大增加,所以最好处理方式是先撤销这个提交(reset --soft HEAD~
),然后更新并解决冲突,最后创建一个新的提交。
3.1.2 错误的处理冲突方式
在发生冲突后,有些同学可能会想到下面的处理方式:
清空当前工作空间
调整冲突部分的代码
然后再次执行更新操作
上面的处理方式很明显是不可行的,因为你调整的代码首选会被IDEA储藏(stash
)起来,然后在更新的第2步中仍然会发生冲突,并且发生冲突时,你的修改尚未恢复储藏(unstash),导致看起来你调整的代码不见了,让人摸不着头脑。
3.1.3 Rebase会改写提交历史
如果在IDEA的更新窗口选择更新类型为Rebase
,则等价于手动执行git fetch && git rebase
或者git pull --rebase
命令。这样的好处是不会生成一个自动合并提交,保持简洁的提交历史。
但是需要注意的是,Rebase
之后,你的本地提交会被改写,虽然提交信息一样,但是commit hash
已经改变了,如下图所示:
在执行完如下的Rebase
命令后,
$ git checkout dev
$ git rebase master
执行结果为:
请注意,结果中的v4
和v5
提交已经被改写了。
3.2 推荐先更新后提交
如果你事先知道会发生冲突,相信你一定不会选择先提交代码,但是冲突是不可避免的,这就要求我们平时养成良好的开发习惯。与其解决提交后的冲突,不如尽早地解决冲突然后提交,这样不仅可以减少一个无意义的自动合并提交,而且可以在冲突发生时简化处理过程。
3.3 养成良好习惯
为了尽量避免冲突发生,建议养成如下开发习惯:
编码前先更新
提交前先更新
提交前检查是否有编译错误
提交粒度尽可能小,描述尽可能准确
修改了公共文件,尽早通知其他成员更新
最后一条,也是最重要的,团队分工要明确
感谢您的阅读,也欢迎您发表关于这篇文章的任何建议,关注我,技术不迷茫!小编到你上高速。
· END ·
最后,关注公众号互联网架构师,在后台回复:2T,可以获取我整理的 Java 系列面试题和答案,非常齐全。
正文结束
推荐阅读 ↓↓↓
1.不认命,从10年流水线工人,到谷歌上班的程序媛,一位湖南妹子的励志故事
2.如何才能成为优秀的架构师?
3.从零开始搭建创业公司后台技术栈
4.程序员一般可以从什么平台接私活?
5.37岁程序员被裁,120天没找到工作,无奈去小公司,结果懵了...
6.IntelliJ IDEA 2019.3 首个最新访问版本发布,新特性抢先看
7.这封“领导痛批95后下属”的邮件,句句扎心!
8.15张图看懂瞎忙和高效的区别!
一个人学习、工作很迷茫?
点击「阅读原文」加入我们的小圈子!
Git 代码防丢指南,再也不怕丢失代码了!相关推荐
- Git 代码防丢指南
我们在日常使用Git的过程中经常会发生一些意外情况,如果处理不当,则可能会出现代码丢失的假象.本文将针对IDEA&Git日常开发中的一些场景,为你层层拨开迷雾,解析常见的错误及其发生原因,让你 ...
- git reset后本地拉取_Git 代码防丢指南
优质文章,第一时间送达 作者:joymufeng 我们在日常使用Git的过程中经常会发生一些意外情况,如果处理不当,则可能会出现代码丢失的假象.本文将针对IDEA&Git日常开发中的一些场景, ...
- 苹果 AirTag 防丢器震撼发布,让你的物品精确定位,防止丢失
在 2021 春季新品发布会上,苹果推出了全新配件 AirTag.这款产品可以配合苹果的"查找"App,帮助追踪和查找重要物品,单件装售价 229 元,四件装售价 779 元. A ...
- 无线智能蓝牙追踪防丢器
蓝牙防丢器,是采用蓝牙技术专门为智能手机设计的防丢器.其工作原理主要是通过距离变化来判断物品是否还控制在你的安全范围.主要适用于手机.钱包.钥匙.行李等贵重物品的防丢,也可用于防止儿童或宠物的走失.防 ...
- 小助手一蓝牙智能防丢器
蓝牙防丢器,是采用蓝牙技术专门为智能手机设计的防丢器.其工作原理主要是通过距离变化来判断物品是否还控制在你的安全范围.主要适用于手机.钱包.钥匙.行李等贵重物品的防丢,也可用于防止儿童或宠物的走失.防 ...
- 苹果AirTags即将发布,防丢器将迎来大发展
根据著名苹果爆料人Jon Prosser的消息,苹果寻物防丢贴AirTags的渲染设计已经曝光.根据Jon Prosser 透露,苹果很有可能会在即将召开的发布会上推出 AirTags.根据此前的消息 ...
- 防丢器拆解对比,小小防丢器内部大有乾坤
iFixit 最近对 AirTag 进行了拆解,同时还拆解了两款竞品三星SmartTag.Tile Mate,并将三者作对比. 苹果在 AirTag 内部几乎没有浪费任何空间,尤其是利用较小的机身实现 ...
- git 获取最新代码_程序员必知:这是一份全面 amp; 详细的 Git与Github 介绍指南
前言 如果你从事 互联网技术研发,那么你一定需要 了解 Git & Github 本文将采用 图 & 表的方式,向你全面介绍 Git 与 Github,包括其功能.应用场景 & ...
- git合并丢失代码问题分析与解决
git合并丢失代码问题分析与解决(错误操作导致) git revert后导致合并代码丢失 起因 我有一个开发分支antd3.x和一个主分支develop,我在合并antd3.x到develop的时候发 ...
- 如何轻松打造一款智能防丢神器?让生活更省心省力
在生活中,你一定遇到过丢东西的情况.比如马上要出门了,却发现钥匙不见了,你翻箱倒柜找半天,看着上班时间临近,急得团团转-- 这时候,如果拥有一款蓝牙防丢器,就能在找不到钥匙的时候,打开App点击&qu ...
最新文章
- DataStage系列教程 (Pivot_Enterprise 行列转换)
- java抽象类与接口区别6_java基础知识(6)---抽象类与接口
- Flume 实战开发指南
- uri uri_什么是URI? 了解许可证术语以确保合规
- asr1009查看接口光衰_python脚本检查H3C交换机光衰
- 常用数据库的字段类型及大小
- Spring 常用的注解
- 松下A6驱动面板操作参数设置与保存
- 无法删除的文件夹怎么办?如何删除删不掉的文件夹
- python生成Androd deviceid
- php读取月日,PHP获取当前时间、年份、月份、日期和天数
- 自定义View之滚动刻度尺,2018/1/14 05
- FPGA EMMC HS400模式verilog驱动开发
- android开发微信分享隐藏logo,前两天刚刚做了微信分享自定义logo和文字,做个标记,从零开始记录...
- 3GPP TS 29244-g30 中英文对照 | 5.4.14 Deferred PDR activation and deactivation
- 分享几个实用的神器 APP
- portal无线认证服务器,无线AC配置portal认证功能portal 认证服务器问题
- 科技向善,腾讯“守护者智能反诈中枢”在行动
- pythonor和and的优先级_python中not、and、or的优先级与详细用法
- 阿里巴巴离职DBA在35岁总结的职业生涯(转)
热门文章
- iOS底层探索之LLVM(一)——初识LLVM
- 新手学习Linux——搭建个人论坛
- C++ template 学习归纳总结4
- PHP上传文件大小限制的问题
- 《基于MFC的OpenGL编程》 13 part 创建2D 和 3D 文字
- Git 报错:error: The requested URL returned error: 401 Unauthorized while accessing
- 安装wordpress时候报错:Parse error: syntax error, unexpected '.', expecting '' or variable (T_VARIABLE)
- 苹果mac虚拟机软件:Parallels Desktop 17(pd虚拟机)Intel专用版
- macos big sur 11 完整离线安装包v11.5.2正式版
- Mac 的 Adobe Creative Cloud 无法连接至服务器的解决办法?