diff git 代碼實現_Git 自救指南:這些坑你都跳得出嗎?

e39b79f1e0fc36a6097de32e045f626f.png

每天都會寫架構師文章,Java技術文章天天更新,感興趣的點個關注再走唄!

Git 雖然因其分布式管理方式,不完全依賴網絡,良好的分支策略,容易部署等優點,已經成為最受歡迎的源代碼管理方式。

但是一分耕耘一分收獲,如果想更好地掌握 git,需要付出大量的學習成本。

即使在各種 GUI 的加持下,也不得不說 git 真的很難,在 V2EX 上也常有如何正確使用 git 的討論,同時在 Stackoverflow 上超過 10w+ 的 git 相關問題也證明了 git 的復雜性。

再加上 git 的官方文檔也一直存在著 “先有雞還是先有蛋” 的問題,雖然文檔非常全面,但如果你不知道你遇到的問題叫什么,那么根本就無從查起。

cbdb1b4da845815d63948332f453257e.png

作為國內領先的研發管理解決方案供應商,CODING 一直致力于在國內普及 git 的使用,為軟件研發提供更高效率。

本文節選自 Katie Sylor-Miller 在日常工作中所遇到過的讓他很頭疼的 git 相關問題,并整理了相應的應對措施,在這里分享給正在學習如何使用 git 的同學們。

當然這些應對措施并不是唯一的,可能你會有其他更好的應對方法,這也恰恰是 git 這套版本控制系統強大的地方。

原文標題:《Oh shit,git!》
原文地址:https://ohshitgit.com/

01

/ 我剛剛好像搞錯了一個很重要的東西,

但是 git 有個神奇的時間機器能幫我復原!/

8ebfbcbeb0c82aaa195235b07e76d284.png

reflog 是一個非常實用的命令,你可以使用這個命令去找回無意間刪除的代碼,或者去掉一些剛剛添加的卻把倉庫里的代碼弄壞的內容。

同時也可以拯救一下失敗的 merge,或者僅僅是為了回退到之前的版本。

02

/ 我 commit 完才想起來

還有一處小地方要修改!/

54b4066deb7fa40cf880ce9f48cd6d65.png

當我 commit 完然后跑測試的時候,經常突然發現忘了在等于號前面加空格。

雖然可以把修改過的代碼再重新 commit 一下,然后 rebase -i 將兩次揉在一起,不過上面的方法會比較快。

03

/ 我要改一下上一個 commit message!/

da6ca542d4c20d25c760f84af51f0db8.png

當你們組對 commit message 有格式要求時,或者當你忘了中英文間要加空格,這個命令能救你狗命。

04

/ 我不小心把本應在新分支上的內容

commit 到 master 了! /

45fdb80c5c411c0a59c0e75da7844f55.png

注意:這個指令必須在錯誤的 commit 后直接執行,如果你已經試了其他的方式,你可能就需要用 git reset HEAD@{number} 來代替 HEAD~ 了。

05

/ 我不小心 commit 到錯誤的分支上了! /

dacf14058dafc4570face6e9a5fa2ca0.png

也有很多人推薦了 cherry-pick 的解決方案,所以選哪個就看你心情了。

a3b7956361de03d084732849444dc0b0.png

06

/ 我執行了 diff 但是啥也沒出現 /

cb3a4cb70c7ab20a67045502d1e12b80.png

Git 不會給通過 add 加入到 staging 區域里面的文件做 diff ,除非你加了 --staged 的標簽,別懷疑了這是一個 feature 不是一個 bug,當然對于第一次碰到這個問題的人來說還是有些不好理解的。

a3b7956361de03d084732849444dc0b0.png

07

/ Git 從入門到放棄 /

98b3a7fc6f7911848ec65717585eb01d.png

為了維護最后的尊嚴 XD

不知道你在使用 git 中有沒有遇到過各種令人掀桌的問題呢?

或者作為 git 資深用戶有什么可以分享的小技巧呢?

歡迎大家在留言區跟我們互動~

原文:
https://mp.weixin.qq.com/s?src=11&timestamp=1562671312&ver=1718&signature=5IIzKphXRTqXzZMMctGzQcI8fZ1CPOwT0eGEKNAQhpuJRxl*9LP*z5d3rA0SsT8lrYybol4S0D31Y630MgZGd608hIRS0iJLEusplHRbUhel8XdAPeJzbKHkseMFNrC4&new=1?mp.weixin.qq.com
來源:微信公眾號
作者:程序員的成長之路

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/538565.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/538565.shtml
英文地址,請注明出處:http://en.pswp.cn/news/538565.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

HDU 4812 D Tree

HDU 4812 思路&#xff1a; 點分治 先預處理好1e6 3以內到逆元 然后用map 映射以分治點為起點的鏈的值a 成他的下標 u 然后暴力跑出以分治點兒子為起點的鏈的值b&#xff0c;然后在map里查找inv[b]*k 代碼&#xff1a; #include<bits/stdc.h> using namespace std; #d…

Angular CLI 安裝

安裝Angular 官網的教程&#xff0c;因為國內網絡環境原因&#xff0c;訪問不了服務器&#xff0c;導致安裝失敗。 1、先安裝NodeJs 安裝教程&#xff1a;http://blog.csdn.net/zengmingen/article/details/72650484 2、通過NodeJs中的模塊npm 命令行安裝 CLI 2.1、設置npm的…

go 寫文件_「go」 項目多個文件編程

golang 學習的時候很多sample 講的都是一個文件的go 文件怎么寫&#xff0c;但是現實中不可能所有的實現都寫到一個文件里面&#xff0c;按照功能的不同&#xff0c;要么拆分成不同的文件&#xff0c;要么拆分成不同的文件。下面有些個人的經驗分享下&#xff0c;如果有問題請指…

CycleGAN 各種變變變

轉載自 簡單介紹了一下GAN和DCGAN的原理。以及如何使用Tensorflow做一個簡單的生成圖片的demo。 Ian Goodfellow對GAN一系列工作總結的ppt&#xff0c;確實精彩&#xff0c;推薦&#xff1a;獨家 | GAN之父NIPS 2016演講現場直擊&#xff1a;全方位解讀生成對抗網絡的原理及未來…

pycharm與webstorm 2017 激活破解

原有的方式已經失效&#xff0c;見下面博文&#xff1a; https://blog.csdn.net/justszh/article/details/81484802

mysql blob 比較_與MSSQL對比學習MYSQL的心得(四)--BLOB數據類型

MYSQL里的BLOB數據類型BLOB是一個二進制大對象&#xff0c;用來存儲可變數量的數據。BLOB類型分為4種&#xff1a;TinyBlob、Blob、MediumBlob、LongBlob&#xff0c;這幾個類型之間的唯一區別是在存儲文件的最大大小上不同。MySQL的四種BLOB類型 類型 大小(單位&#xff1…

Webstorm常用快捷鍵

webstrom 使用 eclipse快鍵鍵 File--settings keymap 選擇 eclipse 原文鏈接&#xff1a;http://www.cnblogs.com/yeminglong/p/5995421.html ------------------以下是webstrom默認的----------------------------------- Ctrl/ 或 CtrlShift/ 注釋&#xff08;// 或者/…

VirtualBox 上安裝Debian 后分辨率設置

VirtualBox 上安裝Debian 后分辨率設置 首先要配置source.list打開終端&#xff0c; su 切換成root用戶&#xff0c; cd /etc/apt 然后編輯source.list rootdebian:/etc/apt# vi source.list 注釋deb cdrom:行&#xff0c;加以下源 deb http://deb.debian.org/debian stretc…

瘋狂的程序員_程序員的樂趣是什么?

作者&#xff1a;Java3y我是一個程序員&#xff0c;外行人都以為我是修電腦的&#xff0c;我笑了笑&#xff0c;隨意ctrl cctrl v了一把&#xff0c;想象著你們因為我的文章而開心不止&#xff0c;我感到充實而欣慰。想象著你們給我拼命點贊的樣子&#xff0c;是多么的滑稽&…

template多行編寫的方式

模板是包在 ECMAScript 2015 反引號 () 中的一個多行字符串。 反引號 () — 注意&#xff0c;不是單引號 () — 允許把一個字符串寫在多行上&#xff0c; 使 HTML 模板更容易閱讀。 反引號&#xff1a;鍵盤數字鍵1 旁邊的&#xff0c;ESC鍵下面的鍵 如果單引號 Component({sel…

sqllite事務和MySQL事務_Android學習---SQLite數據庫的增刪改查和事務(transaction)調用...

上一篇文章中介紹了手工拼寫sql語句進行數據庫的CRUD操作,本文將介紹調用sqlite內置的方法實現CRUD操作,其實質也是通過拼寫sql語句.首先,創建一個新的android項目:其次,查看代碼實現增刪查改:1.創建DB工具類MyDBHelper.java(創建數據庫的操作)packagecom.amos.android_db;impo…

sqlserver2000給賬戶授予所有的權限_你的位置信息權限設置對了么?

位置信息權限是眾多應用權限中的一種&#xff0c;是應用獲取手機地理位置信息的必要憑證。在你首次安裝應用并打開時&#xff0c;通常會出現一連串的權限彈框&#xff0c;如果該應用在其運行過程中會用到你的地理位置信息&#xff0c;那么這些彈框中就會包含一個與位置信息有關…

Python之路,Day1 - Python基礎1

本節內容 Python介紹發展史Python 2 or 3?安裝Hello World程序變量用戶輸入模塊初識.pyc是個什么鬼&#xff1f;數據類型初識數據運算表達式if ...else語句表達式for 循環break and continue 表達式while 循環作業需求 一、 Python介紹 python的創始人為吉多范羅蘇姆&#xf…

mysql 范式化_MySQL-范式和反范式

1.第一范式(1NF)(列不能再拆分)原子性&#xff0c;字段不可分(列的信息)&#xff0c;只要是關系型數據庫&#xff0c;就自動滿足1NF&#xff1b;2.第二范式(2NF)(主鍵唯一&#xff0c;且被依賴)在第一范式基礎上建立的&#xff0c;即滿足第二范式的必須先滿足第一范式。要求DB表…

端口被占用解決辦法

1. 端口被占用解決辦法 netstat -ano | findstr 8080(端口號) taskkill -pid (進程pid) –f轉載于:https://www.cnblogs.com/xaoco/p/9114773.html

java 判斷是否是list_JAVA從頭開始一基礎梳理(4-3)

大家好&#xff0c;今天我們介紹一下java中常用的集合類型。首先&#xff0c;我們先看一下java中集合類型的結構。以上是集合的繼承關系圖&#xff0c;通常我們使用的比較多的是 Set , List , Map以及其衍生的子類和接口實現類。首先給大家介紹一下List&#xff0c;List本身是一…

Python2.x還是3.x?

2.x 和 3.x對于程序員的編碼來說&#xff0c;沒有發生太大的變化&#xff0c;當然也是有變化的&#xff0c;主要是Python內部發生了巨變。 要用3.x的原因是&#xff1a; 1、3.x和2.x版本不兼容。 2、Python庫新增的內容不支持2.x了。 3、2.x版本官方支持到2020年結束。 晚改…

前端網頁廣告無線翻滾_從小白到web前端工程師進階之路 從0到1到更深

互聯網的發展&#xff0c;讓web前端技術發生了翻天覆地的變化&#xff0c;前端開發工程師可以讓網頁內容變得更加生動&#xff0c;為用戶帶來更好的體驗。那么&#xff0c;武漢web前端培訓哪個好&#xff1f;web前端好學嗎&#xff1f;作為一個合格的Web前端工程師&#xff0c;…

PowerDesigner導出表為Excel(轉)

打開腳本運行器CtrlShiftX 導出&#xff1a; ****************************************************************************** Option ExplicitDim rowsNumrowsNum 0 -----------------------------------------------------------------------------Main function -------…

判讀一個對象不為空_ArrayList實現分析(一)——對象創建

ArrayList是java中最常用的集合類之一&#xff0c;它的內部實現是基于數組&#xff0c;因此ArryList可以根據索引實現隨機訪問。ArryList繼承了AbstractList類&#xff0c;并且實現了List, RandomAccess, Cloneable接口。下面詳細分析一下ArrayList的實現&#xff0c;下面的分析…