免费视频淫片aa毛片_日韩高清在线亚洲专区vr_日韩大片免费观看视频播放_亚洲欧美国产精品完整版

打開(kāi)APP
userphoto
未登錄

開(kāi)通VIP,暢享免費(fèi)電子書(shū)等14項(xiàng)超值服

開(kāi)通VIP
10 個(gè)迅速提升你 Git 水平的提示

我們推出了兩個(gè)教程:熟悉Git的基本功能讓你在開(kāi)發(fā)團(tuán)隊(duì)中熟練的使用Git . 我們所討論的命令足夠一個(gè)開(kāi)發(fā)者在Git使用方面游刃有余。在這篇文章中,我們?cè)噲D探索怎樣有效的管理你的時(shí)間和充分的使用Git提供的功能。

注:本文中,一些命令包含了方括號(hào)中的部分內(nèi)容(例如:git add -p [file_name]).在這些示例中,你將插入必要的數(shù)字、標(biāo)示符等等,如果沒(méi)有方括號(hào)。

漠天
翻譯于 11個(gè)月前

4人頂

 翻譯的不錯(cuò)哦!

1. Git自動(dòng)補(bǔ)全

假使你使用命令行工具運(yùn)行Git命令,那么每次手動(dòng)輸入各種命令是一件很令人厭煩的事情。
為了解決這個(gè)問(wèn)題,你可以啟用Git的自動(dòng)補(bǔ)全功能,完成這項(xiàng)工作僅需要幾分鐘。

為了得到這個(gè)腳本,在Unix系統(tǒng)下運(yùn)行以下命令:

1
2
cd ~
curl https://raw.github.com/git/git/master/contrib/completion/git-completion.bash -o ~/.git-completion.bash

然后,添加下面幾行到你的 ~/.bash_profile 文件中:

1
2
3
if -f ~/.git-completion.bash ]; then
    . ~/.git-completion.bash
fi

盡管早些時(shí)候我們已經(jīng)提到這個(gè),但是強(qiáng)調(diào)的不夠充分。如果你想使用git的全部功能特性,
你絕對(duì)應(yīng)該切換到命令行界面!

quentingui
翻譯于 11個(gè)月前

1人頂

 翻譯的不錯(cuò)哦!

2. 在 Git 中忽略文件

你是不是很煩那些編譯過(guò)的文件 (比如 .pyc) 出現(xiàn)在你的 Git 倉(cāng)庫(kù)中?或者說(shuō)你已經(jīng)受夠了已經(jīng)把它們都加進(jìn)了 Git 倉(cāng)庫(kù)?好了,這有個(gè)辦法可以讓你告訴 Git 忽略掉那些特定的文件和文件夾。只需要?jiǎng)?chuàng)建一個(gè)名為 .gitignore 然后列出那些你不希望 Git 跟蹤的文件和文件夾。你還可以添加例外,通過(guò)使用感嘆號(hào)(!)。

1
2
3
4
5
*.pyc
*.exe
my_db_config/
!main.pyc
開(kāi)源中國(guó)匿名會(huì)員
翻譯于 11個(gè)月前

0人頂

 翻譯的不錯(cuò)哦!

其它翻譯版本(1)

3. 是誰(shuí)弄亂了我的代碼?

當(dāng)事情出錯(cuò)時(shí),先去指責(zé)別人是人類(lèi)的天性之一。如果你的產(chǎn)品服務(wù)器掛了,使用git blame命令可以很容易找出罪魁禍?zhǔn)?。這個(gè)命令可以將文件中的每一行的作者、最新的變更提交和提交時(shí)間展示出來(lái)。

1
git blame [file_name]

在下面的截圖中你可以看到命令是如何在更大的目錄中搜尋。

0x0bject
翻譯于 11個(gè)月前

1人頂

 翻譯的不錯(cuò)哦!

4. 查看倉(cāng)庫(kù)歷史記錄

上一節(jié)我們已經(jīng)學(xué)習(xí)了如何使用 git log ,不過(guò),這里還有三個(gè)你應(yīng)該知道的選項(xiàng)。

  • --oneline- 壓縮模式,在每個(gè)提交的旁邊顯示經(jīng)過(guò)精簡(jiǎn)的提交哈希碼和提交信息,以一行顯示。

  • --graph- 圖形模式,使用該選項(xiàng)會(huì)在輸出的左邊繪制一張基于文本格式的歷史信息表示圖。如果你查看的是單個(gè)分支的歷史記錄的話,該選項(xiàng)無(wú)效。

  • --all- 顯示所有分支的歷史記錄

把這些選項(xiàng)組合起來(lái)之后,輸出看起來(lái)會(huì)像這樣:

開(kāi)源中國(guó)匿名會(huì)員
翻譯于 11個(gè)月前

2人頂

 翻譯的不錯(cuò)哦!

5. 絕對(duì)不要丟失對(duì)Commit的跟蹤

假設(shè)你不小心提交了些你不想要的東西,不得不做一次強(qiáng)制重置來(lái)恢復(fù)到之前的狀態(tài)。然后,你意識(shí)到在這一過(guò)程中你丟失了其它一些信息并且想要把它們找回來(lái),或者至少瞅一眼。這正是git reflog可以做到的。

一個(gè)簡(jiǎn)單的git log命令可以為你展示最后一次commit,以及它的父親,還有它父親的父親等等。而git reflog則列出了head曾經(jīng)指向過(guò)的一系列commit。要明白它們只存在于你本機(jī)中;而不是你的版本倉(cāng)庫(kù)的一部分,也不包含在push和merge操作中。

如果我運(yùn)行g(shù)it log命令,我可以看到一些commit,它們都是我倉(cāng)庫(kù)的一部分:

然而,一個(gè)git reflog命令則展示了一次commit (b1b0ee9–HEAD@{4}),它正是我剛才進(jìn)行強(qiáng)制重置時(shí)弄丟的:

lwei
翻譯于 11個(gè)月前

1人頂

 翻譯的不錯(cuò)哦!

6. 暫存文件的部分改動(dòng)

一般情況下,創(chuàng)建一個(gè)基于特性的提交是比較好的做法,意思是每次提交都必須代表一個(gè)新特性的產(chǎn)生或者是一個(gè)bug的修復(fù)。如果你修復(fù)了兩個(gè)bug,或是添加了多個(gè)新特性但是卻沒(méi)有提交這些變化會(huì)怎樣呢?在這種情況下,你可以把這些變化放在一次提交中。但更好的方法是把文件暫存(Stage)然后分別提交。

例如你對(duì)一個(gè)文件進(jìn)行了多次修改并且想把他們分別提交。這種情況下,你可以在 add 命令中加上 -p 參數(shù)

1
git add -p [file_name]

我們來(lái)演示一下在 file_name 文件中添加了3行文字,但只想提交第一行和第三行。先看一下 git diff 顯示的結(jié)果:

然后再看看在 add 命令中添加 -p 參數(shù)是怎樣的?

看上去,Git 假定所有的改變都是針對(duì)同一件事情的,因此它把這些都放在了一個(gè)塊里。你有如下幾個(gè)選項(xiàng):

  • 輸入 y 來(lái)暫存該塊

  • 輸入 n 不暫存

  • 輸入 e 手工編輯該塊

  • 輸入 d 退出或者轉(zhuǎn)到下一個(gè)文件

  • 輸入 s 來(lái)分割該塊

在我們這個(gè)例子中,最終是希望分割成更小的部分,然后有選擇的添加或者忽略其中一部分。

正如你所看到的,我們添加了第一行和第三行而忽略了第二行。之后你可以查看倉(cāng)庫(kù)狀態(tài)之后并進(jìn)行提交。

鑒客
翻譯于 11個(gè)月前

1人頂

 翻譯的不錯(cuò)哦!

7. 壓縮多個(gè)Commit

當(dāng)你提交代碼進(jìn)行代碼審查時(shí)或者創(chuàng)建一次pull request (這在開(kāi)源項(xiàng)目中經(jīng)常發(fā)生),你的代碼在被接受之前會(huì)被要求做一些變更。于是你進(jìn)行了變更,并且直到下一次審查之前你沒(méi)有再次被要求進(jìn)行變更過(guò)。在你知道又要進(jìn)行變更之前,你已經(jīng)有了一些額外的commit。理想情況下,你可以用rebase命令把多個(gè)commit壓縮成一個(gè)。

1
git rebase -i HEAD~[number_of_commits]

如果你想要壓縮最后兩個(gè)commit,你需要運(yùn)行下列命令。

1
git rebase -i HEAD~2

運(yùn)行該命令時(shí),你會(huì)看到一個(gè)交互界面,列出了許多commit讓你選擇哪些需要進(jìn)行壓縮。理想情況下,你選擇最后一次commit并把其它老commit都進(jìn)行壓縮。

然后會(huì)要求你為新的commit錄入提交信息。這一過(guò)程本質(zhì)上重寫(xiě)了你的commit歷史。

lwei
翻譯于 11個(gè)月前

1人頂

 翻譯的不錯(cuò)哦!

8. Stash未提交的更改

你正在修改某個(gè)bug或者某個(gè)特性,又突然被要求展示你的工作。而你現(xiàn)在所做的工作還不足以提交,這個(gè)階段你還無(wú)法進(jìn)行展示(不能回到更改之前)。在這種情況下, git stash可以幫助你。stash在本質(zhì)上會(huì)取走所有的變更并存儲(chǔ)它們?yōu)橐詡鋵?lái)使用。stash你的變更,你只需簡(jiǎn)單地運(yùn)行下面的命令-

1
git stash

希望檢查stash列表,你可以運(yùn)行下面的命令:

1
git stash list

如果你想要解除stash并且恢復(fù)未提交的變更,你可以進(jìn)行apply stash:

1
git stash apply

在屏幕截圖中,你可以看到每個(gè)stash都有一個(gè)標(biāo)識(shí)符,一個(gè)唯一的號(hào)碼(盡管在這種情況下我們只有一個(gè)stash)。如果你只想留有余地進(jìn)行apply stash,你應(yīng)該給apply添加特定的標(biāo)識(shí)符:

1
git stash apply stash@{2}

無(wú)若
翻譯于 11個(gè)月前

0人頂

 翻譯的不錯(cuò)哦!

9.檢查丟失的提交

盡管 reflog 是唯一檢查丟失提交的方式。但它不是適應(yīng)用于大型的倉(cāng)庫(kù)。那就是 fsck(文件系統(tǒng)檢測(cè))命令登場(chǎng)的時(shí)候了。

1
git fsck --lost-found

這里你可以看到丟掉的提交。你可以通過(guò)運(yùn)行 git show [commit_hash] 查看提交之后的改變或者運(yùn)行g(shù)it merge [commit_hash] 來(lái)恢復(fù)到之前的提交。

git fsck 相對(duì)reflog是有優(yōu)勢(shì)的。比方說(shuō)你刪除一個(gè)遠(yuǎn)程的分支然后關(guān)閉倉(cāng)庫(kù)。 用fsck 你可以搜索和恢復(fù)已刪除的遠(yuǎn)程分支。


irglsexy
翻譯于 11個(gè)月前

0人頂

 翻譯的不錯(cuò)哦!

10. Cherry Pick

我把最優(yōu)雅的Git命令留到了最后。cherry-pick命令是我目前為止最喜歡的git命令,既是因?yàn)樗淖置嬉馑?,也因?yàn)樗墓δ堋?/p>

簡(jiǎn)而言之,cherry-pick就是從不同的分支中撿出一個(gè)單獨(dú)的commit,并把它和你當(dāng)前的分支合并。如果你以并行方式在處理兩個(gè)或以上分支,你可能會(huì)發(fā)現(xiàn)一個(gè)在全部分支中都有的bug。如果你在一個(gè)分支中解決了它,你可以使用cherry-pick命令把它c(diǎn)ommit到其它分支上去,而不會(huì)弄亂其他的文件或commit。

讓我們來(lái)設(shè)想一個(gè)用得著它的場(chǎng)景。我現(xiàn)在有兩個(gè)分支,并且我想cherry-pick b20fd14: Cleaned junk 這個(gè)commit到另一個(gè)上面去。

我切換到想被cherry-pick應(yīng)用到的這個(gè)分支上去,然后運(yùn)行了如下命令:

1
git cherry-pick [commit_hash]

盡管我們這次完成了一次干凈的cherry-pick,你也應(yīng)該意識(shí)到這個(gè)命令可能會(huì)產(chǎn)生沖突。所以用它時(shí)請(qǐng)無(wú)比小心。

htfy96
翻譯于 11個(gè)月前

0人頂

 翻譯的不錯(cuò)哦!

總結(jié)

說(shuō)著說(shuō)著就到了文章的最后,我認(rèn)為這些技巧會(huì)讓你的 Git 水平提升到一個(gè)新的高度。Git 是最棒的,它幾乎能實(shí)現(xiàn)你所能想到的事情。因此,要經(jīng)常挑戰(zhàn)自己的Git水平。最后你很有可能會(huì)學(xué)到新的東西。

本站僅提供存儲(chǔ)服務(wù),所有內(nèi)容均由用戶(hù)發(fā)布,如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊舉報(bào)。
打開(kāi)APP,閱讀全文并永久保存 查看更多類(lèi)似文章
猜你喜歡
類(lèi)似文章
10 Tips to Push Your Git Skills to the Next Level
工作流一目了然,看小姐姐用動(dòng)圖展示 10 大 Git 命令
你所需要知道的一些git 的使用命令:Git大師
從Git倉(cāng)庫(kù)中恢復(fù)已刪除的分支或丟失的commit
你需要知道的12個(gè)Git高級(jí)命令
GIT版本配置管理
更多類(lèi)似文章 >>
生活服務(wù)
分享 收藏 導(dǎo)長(zhǎng)圖 關(guān)注 下載文章
綁定賬號(hào)成功
后續(xù)可登錄賬號(hào)暢享VIP特權(quán)!
如果VIP功能使用有故障,
可點(diǎn)擊這里聯(lián)系客服!

聯(lián)系客服