過來人告訴你城丧,去工作前最好還是學學Git

前言

只有光頭才能變強。

文本已收錄至我的GitHub精選文章,歡迎Starhttps://github.com/ZhongFuCheng3y/3y

之前遇到過很多同學私信問我:「三歪羡藐,我馬上要實習了,我要在實習前學些什么做準備懊跣怼仆嗦?」

三歪在實習之前也同樣問過自己當時的部門老大。

如果再給我一次機會先壕,我會先去花點時間去學學Git瘩扼。

Git我相信大家對它應該不陌生吧?但凡用過GitHub的同學應該多多少少都會了解一下Git

不知道當時大家學Git的時候是看哪個教程的垃僚,我看的是廖雪峰老師的Git系列的集绰。

(別看到廖雪峰就以為是廣告了啊,哈哈哈哈谆棺,這篇純原創(chuàng)分享)

image

分享一下三歪的經歷

剛實習的時候栽燕,一直都忙著看各種東西。有一天改淑,我學長說:我看你也學了一些基礎了碍岔,我們來看看公司的代碼吧,看看我們生產環(huán)境是怎么做的朵夏。

于是我學長丟了一個Git鏈接給三歪

https://github.com/ZhongFuCheng3y/3y.git

那三歪做了什么蔼啦?三歪去IDEA下把這個Git給Clone下來:

image

我用Clone完了以后,我學長又補了一句:這個項目不是用master分支的哦仰猖,你切換一下分支捏肢。

三歪:啥奈籽?切換分支?咋整鸵赫?我忘了衣屏。

我學長看了下我,貌似不咋會切換分支奉瘤,就說:“我來吧”勾拉。

于是在命令行終端一頓操作后,對三歪說:“好了”

三歪:“我對Git不是很熟悉盗温,之前一直都是在IDEA上操作的藕赞。你們一般用命令行多還是圖形界面的多呀?”

我學長:“這沒什么卖局,反正工具這東西斧蜕,學學就行,不是什么大問題砚偶。也沒必要說很仔細去學它批销,就工具嘛”

三歪:“嗯”

時間飛逝,又過了一段時間...

三歪被分配了一個需求染坯,于是就需要新建分支去做這個需求了均芽。所有的標準應用線上走的是master分支,公司通過一個發(fā)布系統(tǒng)來控制發(fā)布版本单鹿、以及整套上下線的流程掀宋。

image

于是我要先在發(fā)布系統(tǒng)里邊新建Git分支:

image

完了以后,我就在IDEA界面上選擇那個被我新建完的分支

image

但發(fā)現(xiàn)我死活找不到...于是我就問我學長:我在發(fā)布系統(tǒng)里邊新建了分支仲锄,為什么在IDEA上找不到熬⒚睢?

學長:“怎么會呢儒喊,我看看”镣奋。

找了一會,他問我:“你fetch 過了嗎怀愧?”

三歪:“啥侨颈?”

于是他拿著我的電腦,打開了終端芯义,又以是命令行的方式敲了一頓哈垢,問我:“這是不是你新建的分支?“

三歪點了點頭毕贼,于是我學長說:”好了,你再看看“蛤奢。

后來發(fā)現(xiàn)鬼癣,新建完遠程分支陶贼,如果在IDEA上要能感知到,可以在pull界面上刷新一下待秃,那就能找到了拜秧。

image

也不是說命令行一定會就比界面牛逼,其實IDEA的Git功能也做得挺好的≌掠簦現(xiàn)在我都是混合使用枉氮,一些操作用命令行,一些操作用IDEA快捷鍵暖庄。

commitpush的時候就喜歡用快捷鍵聊替。command+k和command +shift+k我就感覺比敲命令要快不少。

這些都是個人習慣的問題培廓,也無對錯之分惹悄,怎么方便怎么來。

其實也不是所有的系統(tǒng)都會走發(fā)布系統(tǒng)的(有標準應用肩钠,非標準應用)泣港。如果要自己寫一個啟動的腳本,一般我們會做些什么价匠?無非就是用Git拉最新的代碼当纱,然后用maven打個包,然后啟動踩窖。

image

理解Git

如果你看過上一篇《三歪給女朋友講解什么是Git》應該能大概了解什么是Git了坡氯。

其實我覺得學Git主要理解工作區(qū) -> 暫存區(qū)->倉庫 這幾個概念。

image

我們使用Git其實絕大部分的操作都是在本地上完成的毙石,比如說add 和commit廉沮。

只有我們push的時候,才會把本地完成好的內容推到遠程倉庫

通過上一篇文章我們知道在每個人的本地都有完整的歷史版本徐矩,所以我們可以在本地就能穿梭到不同的版本滞时,然后將修改之后的代碼再重新提交到遠程倉庫上。

所謂的工作區(qū)實際上就是我們真正的的本地目錄滤灯。

我們在本地添加文件后坪稽,需要add到暫存區(qū),文件一旦被add到了暫存區(qū)鳞骤,意味著Git能追蹤到這個文件窒百。

當我們修改到一定程度之后,我們會執(zhí)行一次提交commit豫尽,在提交的時候我們會”備注“自己這次的提交修改了什么內容篙梢。

一次commit在Git就是一個版本,Git是版本控制的軟件美旧,我們可以隨意穿梭到任何的版本中渤滞,修改代碼贬墩。

暫存區(qū)是這么一個概念呢插掂?

暫存區(qū)就像購物車秒啦,沒到付款的時候你都不確定購物車里的東西全部都是要的。每拿一件商品就付一次款撑帖,那麻煩可大了绪励。

從宏觀上看肿孵,Git其實有本地和遠程的概念,只是本地又分了工作區(qū)疏魏、暫存區(qū)停做、本地倉庫。再次強調:我們操作幾乎都是在本地完成蠢护,每個人的本地都會有所有歷史版本信息雅宾。

image

我們一般會新建分支去支持每一次的修改。

其實分支這個概念也挺好理解的:我們需要并行開發(fā)葵硕,同時我們又不關心對方改的是什么內容眉抬,改的是什么文件。因此我們需要在自己的專屬環(huán)境下去修改內容懈凹,只要把最終修改完后的內容合并到一個主分支就OK了蜀变。

image

假設三歪做完了,經過校驗通過后介评,把自己的代碼merge(合并)到origin/master分支后库北,然后就發(fā)布上線啦。

隨后们陆,雞蛋也做完了寒瓦,自己的分支校驗完了以后,他此時也想把自己的代碼合并到origin/master坪仇。不料杂腰,他改的代碼跟三歪改的代碼有沖突了(Git不知道選擇誰的的代碼),那雞蛋只能手動merge了椅文。

綜合來看喂很,我們使用Git大多數(shù)的場景就是各自分支開發(fā),然后各自在本地commit(提交)皆刺,最后匯總到master分支少辣。

image

所以,我們學Git大多數(shù)就學怎么實現(xiàn)分支的增刪改羡蛾、切換以及版本的穿梭漓帅。

學習Git的小tips:

Unix/Linux 命令中,- 后一般跟短命令選項(通常是單字母,也有一些命令是例外的)忙干,-- 后一般跟長命令選項屯伞。如果只有一個單獨的--,后面不緊跟任何選項豪直,則表示命令選項結束,后續(xù)的都作為命令的參數(shù)而不是選項珠移。

例如:git checkout -- filename filename作為git checkout 的參數(shù)弓乙,而不是選項。

日常Git使用場景

钧惧、如果這個項目的代碼我們在本地還沒有暇韧,我們先去GitLab里邊找對應的Git地址,然后Clone到本地:

git clone https://github.com/ZhongFuCheng3y/3y.git
image

浓瞪、接到了新的需求懈玻,我們要新建一個分支,然后基于這個分支去開發(fā):

git checkout -b feature/sanwaiAddLog

在開發(fā)的時候乾颁,我們肯定會有兩個操作:

  • 在原來的基礎上添加新的文件
  • 在原有的文件上修改

涂乌、不管怎么樣,等我們做到一定程度了英岭,我們都會提交代碼湾盒。如果我們添加了新的文件,我們需要先add诅妹,然后再commit

git add .
git commit  -m "try to commit files to GitHub, i am java3y"

罚勾、假設我們一切順利,在沒人打擾的情況下已經寫好了代碼了吭狡,然后我們會把自己的分支push到遠程倉庫

git push

尖殃、假設我們寫到一半,其他小伙伴已經把他的代碼merge到主分支了划煮,我們也需要把他最新的 代碼給pull拉取下來(可以 git fetch + git merge 替代)送丰。

git pull

如果沒有沖突,那git就會把他的代碼給merge到我當前的分支上般此。如果有沖突蚪战,Git會提醒我去手動解決一下沖突。

铐懊、假設我們寫到一半了邀桑,現(xiàn)在工作區(qū)的代碼都已經commit了。此時同事說要不幫忙一起排查一個問題科乎,同事一般用的是自己分支壁畸,于是就得問他:你用的哪個分支啊?于是得把他的分支給拉下來捏萍,看看他的代碼哪兒有問題

git fecth -- 手動拉取遠程倉庫更新的信息
git checkout  分支名   -- 切換到他的分支

現(xiàn)在切換到他的分支太抓,相當于你的環(huán)境跟他的環(huán)境是一模一樣的,于是就可以愉快地一起看Bug了令杈。

走敌、假設我們寫到一半了,現(xiàn)在工作區(qū)的代碼還沒commit《贺現(xiàn)在有同事說要排查問題或者一個新的Bug被發(fā)現(xiàn)了掉丽,要緊急切換到其他的分支。現(xiàn)在我又不想commit(我就寫了一半异雁,編譯還報著錯誤捶障,沒理由讓我commit吧)。

這時纲刀,我會把工作區(qū)的代碼先stash到暫存區(qū)給保存起來项炼,然后就可以愉快地切換其他的分支了。

git stash

等我解決完另一個bug或者幫別人看完問題了示绊,我再把剛剛保存在暫存區(qū)的代碼給撈出來锭部,繼續(xù)干活

git stash pop

、我一直在修Bug面褐,現(xiàn)在的分支已經被我搞得人摸鬼樣了空免,我非常難受,甚至不知道自己在這個過程中改了多少東西了盆耽。

image

思路已經完全被打亂了蹋砚,我想回到一個穩(wěn)定的commit重新出發(fā),重來吧(通過下面的命令摄杂,把工作區(qū)的代碼都改成對應commit的代碼了)坝咐。

git reset --hard  版本號

那我怎么找到版本號呢?Git也是有日志的:

git log --pretty=oneline
image

常用的Git命令

查看Git工作區(qū)析恢、暫存區(qū)的變更情況(可以知道哪些沒有commit墨坚、哪些沒有被Git追蹤):git status

拉取遠程最新的變更到本地:git fetch

切換分支:git checkout 分支名

將代碼還原到某個版本(包括工作目錄):git reset --hard 版本號

查看Git的提交(commit)記錄:git log

將代碼還原到某個版本后,后悔了映挂,想重新回去泽篮,但在提交記錄已經找不到了。git reset --hardreset 之后的 commit都給抹殺掉了柑船。找到最近的執(zhí)行Git命令:git reflog

還原到某個版本了帽撑,現(xiàn)在我為了穩(wěn)健,不想再原來的分支上修改了鞍时,再新建一個分支吧(-b 參數(shù)把當前分支切換到了要創(chuàng)建的分支上):git checkout -b 分支名

我們把上一次還是”相對穩(wěn)健“的分支合并到我新建的分支上:git merge 分支

突然想看看現(xiàn)在有多少個分支:git branch -a

新增幾個文件了亏拉,隨手git add一下吧

改得差不多了扣蜻,隨手git commit -m一下吧,最好還是寫好備注及塘,不然以后等改多了莽使,你都不知道你改了什么啦。

改完了笙僚,提交到遠程吧:git push

想把遠程分支最新的代碼給拉下來芳肌,然后合并到本地上。我們可以用git fetchgit merge來實現(xiàn)肋层,也可以通過git pull來實現(xiàn)庇勃。一般我用的都是git fetch+git merge,這樣會更加可控一些

有的時候槽驶,本地分支在master分支,然后忘了切其他的分支去修改鸳兽,直接在master改了掂铐,然后也push到遠程了。等你發(fā)現(xiàn)的時候揍异,你會真的想罵自己全陨。

咋辦?最簡單的辦法其實我們還是可以git reset --hard到對應的版本衷掷,然后將其修改或者復原辱姨,再強制提交到master分支:git push -u origin/master -f

image

三歪瞎扯

在這篇文章中,我列出的Git常用的命令其實并不多吧戚嗅。

像很多博客講的diff雨涛、tagconfig之類的命令我都沒有講懦胞,我這邊現(xiàn)實開發(fā)時這些命令也沒怎么用過...

如果覺得我說漏的替久,可以在評論區(qū)補充,一起學習躏尉。

其實現(xiàn)在IDEA也很強大蚯根,很多時候都可以配合IDEA給我們提供的Git去做很多事。有的場景敲命令會比較方便胀糜,有的時候就直接圖形化界面就比較方便颅拦。

diff這個功能而言, 肯定還是圖形界面好用一些吧(至少我是這樣認為的

IDEA配合一些快捷鍵教藻,使用Git也能爽得飛起距帅。Git始終也只是一個工具,如果你有興趣可以了解它的實現(xiàn)(我覺得大部分人可能不知道它是怎么實現(xiàn)的)括堤;

如果沒興趣看它的實現(xiàn)锥债,了解它是怎么使用的,也足夠應付日常的開發(fā)場景了。

總的來說哮肚,現(xiàn)在的互聯(lián)網公司大多數(shù)還是用Git的登夫,Git本身使用上其實不難,只要理解了Git是干嘛的允趟,它有個本地倉庫的概念恼策,它可以來回穿梭各種版本,然后將本地的信息提交到遠程潮剪,跟著教程把常用的命令敲敲也差不多了涣楷。

如果實在是不懂,也別慌(我都給你們打了個樣了)抗碰;主動認慫狮斗,虛心求教,同事們都不會嫌棄你的弧蝇。

如果實習之前不知道要準備什么去公司碳褒,要是對Git不了解,我覺得Git可以有占一席之位看疗。

更多Git命令和參考資料:

各類知識點總結

下面的文章都有對應的原創(chuàng)精美PDF沙峻,在持續(xù)更新中,可以來找我催更~

涵蓋Java后端所有知識點的開源項目(已有8K+ star):

我是三歪两芳,一個想要變強的男人摔寨,感謝大家的點贊收藏和轉發(fā),下期見怖辆。給三歪點個贊是复,對三歪真的非常重要!

?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末竖螃,一起剝皮案震驚了整個濱河市佑笋,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌斑鼻,老刑警劉巖蒋纬,帶你破解...
    沈念sama閱讀 206,839評論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異坚弱,居然都是意外死亡蜀备,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,543評論 2 382
  • 文/潘曉璐 我一進店門荒叶,熙熙樓的掌柜王于貴愁眉苦臉地迎上來碾阁,“玉大人,你說我怎么就攤上這事些楣≈祝” “怎么了宪睹?”我有些...
    開封第一講書人閱讀 153,116評論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長蚕钦。 經常有香客問我亭病,道長,這世上最難降的妖魔是什么嘶居? 我笑而不...
    開封第一講書人閱讀 55,371評論 1 279
  • 正文 為了忘掉前任罪帖,我火速辦了婚禮,結果婚禮上邮屁,老公的妹妹穿的比我還像新娘整袁。我一直安慰自己,他們只是感情好佑吝,可當我...
    茶點故事閱讀 64,384評論 5 374
  • 文/花漫 我一把揭開白布坐昙。 她就那樣靜靜地躺著,像睡著了一般芋忿。 火紅的嫁衣襯著肌膚如雪炸客。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,111評論 1 285
  • 那天盗飒,我揣著相機與錄音,去河邊找鬼陋桂。 笑死逆趣,一個胖子當著我的面吹牛,可吹牛的內容都是我干的嗜历。 我是一名探鬼主播宣渗,決...
    沈念sama閱讀 38,416評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼梨州!你這毒婦竟也來了痕囱?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 37,053評論 0 259
  • 序言:老撾萬榮一對情侶失蹤暴匠,失蹤者是張志新(化名)和其女友劉穎鞍恢,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體每窖,經...
    沈念sama閱讀 43,558評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡帮掉,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 36,007評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了窒典。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片蟆炊。...
    茶點故事閱讀 38,117評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖瀑志,靈堂內的尸體忽然破棺而出涩搓,到底是詐尸還是另有隱情污秆,我是刑警寧澤,帶...
    沈念sama閱讀 33,756評論 4 324
  • 正文 年R本政府宣布昧甘,位于F島的核電站良拼,受9級特大地震影響,放射性物質發(fā)生泄漏疾层。R本人自食惡果不足惜将饺,卻給世界環(huán)境...
    茶點故事閱讀 39,324評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望痛黎。 院中可真熱鬧予弧,春花似錦、人聲如沸湖饱。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,315評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽井厌。三九已至蚓庭,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間仅仆,已是汗流浹背器赞。 一陣腳步聲響...
    開封第一講書人閱讀 31,539評論 1 262
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留墓拜,地道東北人港柜。 一個月前我還...
    沈念sama閱讀 45,578評論 2 355
  • 正文 我出身青樓,卻偏偏與公主長得像咳榜,于是被迫代替她去往敵國和親夏醉。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 42,877評論 2 345