自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

七個(gè)你無(wú)法忽視的 Git 使用技巧

開(kāi)發(fā) 前端
與其他技術(shù)相比,Git應(yīng)該拯救了更多開(kāi)發(fā)人員的飯碗。只要你經(jīng)常使用Git保存自己的工作,你就一直有機(jī)會(huì)可以將代碼退回到之前的狀態(tài),因此就可以挽回那些你深夜里迷迷糊糊犯下的錯(cuò)誤。

 

 

與其他技術(shù)相比,Git應(yīng)該拯救了更多開(kāi)發(fā)人員的飯碗。只要你經(jīng)常使用Git保存自己的工作,你就一直有機(jī)會(huì)可以將代碼退回到之前的狀態(tài),因此就可以挽回那些你深夜里迷迷糊糊犯下的錯(cuò)誤。

盡管這么說(shuō),Git的命令行界面可是出了名的難掌握。接下來(lái),就給大家介紹7個(gè)小技巧,***限度發(fā)揮Git的作用。

通常,大部分時(shí)間我們都只會(huì)用到add、commit、branchpush/pull這 些命令。大部分人熟悉這套只往一個(gè)方向運(yùn)轉(zhuǎn)的工作流。你們有沒(méi)有想過(guò),如果自己往倉(cāng)庫(kù)中添加了錯(cuò)誤的文件,或是將代碼提交到了錯(cuò)誤的分支,而且提交信息還 寫(xiě)錯(cuò)了的話,自己怎樣才能取消之前的操作?如果你也是按照上面漫畫(huà)中所描繪的一樣操作的(即刪除本地項(xiàng)目文件夾,再重新下載倉(cāng)庫(kù)),那么你就有必要了解下 面這些Git使用技巧了。

 

[[157597]]

1. 修改錯(cuò)誤的提交信息commit message

提交信息很長(zhǎng)時(shí)間內(nèi)會(huì)一直保留在你的代碼庫(kù)code base中,所以你肯定希望通過(guò)這個(gè)信息正確地了解代碼修改情況。 下面這個(gè)命令可以讓你編輯最近一次的提交信息,但是你必須確保沒(méi)有對(duì)當(dāng)前的代碼庫(kù)working copy做修改,否則這些修改也會(huì)隨之一起提交。

  1. $ git commit --amend -m YOUR-NEW-COMMIT-MESSAGE

假如你已經(jīng)將代碼提交(git commit)推送(git push)到了遠(yuǎn)程分支,那么你需要通過(guò)下面的命令強(qiáng)制推送這次的代碼提交。

  1. $ git push <remote> <branch> --force

你可以關(guān)注Stack Overflow網(wǎng)站上的這條問(wèn)答, 獲取更多詳情。

2. 提交之前撤銷(xiāo) git add

如果你往暫存區(qū)staging area中加入了一些錯(cuò)誤的文件,但是還沒(méi)有提交代碼。你可以使用一條簡(jiǎn)單的命令就可以撤銷(xiāo)。如果只需要移除一個(gè)文件,那么請(qǐng)輸入:

  1. $ git reset <文件名>

或者如果你想從暫存區(qū)移除所有沒(méi)有提交的修改:

  1. $ git reset

你可以關(guān)注Stack Overflow網(wǎng)站上的這條問(wèn)答, 獲取更多詳情。

3. 撤銷(xiāo)最近一次代碼提交

有時(shí)候你可能會(huì)不小心提交了錯(cuò)誤的文件或一開(kāi)始就遺漏了某些東西。下面這三步操作可以幫助你解決這個(gè)問(wèn)題。

  1. $ git reset --soft HEAD~1

  2. # 對(duì)工作文件進(jìn)行必要的更改

  3. $ git add -A .

  4. $ git commit -c ORIG_HEAD

你執(zhí)行***個(gè)命令時(shí),Git會(huì)將HEAD指針后移到此前的一次提交,之后你才能移動(dòng)文件或作必要的修改。

然后你就可以添加所有的修改,而且當(dāng)你執(zhí)行***的命令時(shí),Git會(huì)打開(kāi)你的默認(rèn)文本編輯器,其中會(huì)包含上一次提交時(shí)的信息。如果愿意的話,你可以修改提交信息,或者你也可以在***的命令中使用-C而不是-c,來(lái)跳過(guò)這一步。

4. Git倉(cāng)庫(kù)撤銷(xiāo)至前一次提交時(shí)的狀態(tài)

“撤銷(xiāo)”revert在許多情況下是非常有必要的——尤其是你把代碼搞的一團(tuán)糟的情況下。最常見(jiàn)的情況是,你想回到之前代碼版本,檢查下那個(gè)時(shí)候的代碼庫(kù),然后再回到現(xiàn)在狀態(tài)。這可以通過(guò)下面的命令實(shí)現(xiàn):

  1. $ git checkout <SHA>

“”是你想查看的提交擁有的哈希值Hash Code中前8至10個(gè)字符。 這個(gè)命令會(huì)使<HEAD>指針脫離detach,可以讓你在不檢出check out任何分支的情況下查看代碼——脫離HEAD并不像聽(tīng)上去那么可怕。如果你想在這種情況下提交修改,你可以通過(guò)創(chuàng)建新的分支來(lái)實(shí)現(xiàn):

  1. $ git checkout -b <SHA>

要想回到當(dāng)前的工作進(jìn)度,只需要檢出check out你之前所在的分支即可。

你可以關(guān)注Stack Overflow網(wǎng)站上的這條問(wèn)答, 獲取更多詳情。

5. 撤銷(xiāo)合并Merge

要想撤銷(xiāo)合并,你可能必須要使用恢復(fù)命令HARD RESET回到上一次提交的狀態(tài)。“合并”所做的工作基本上就是重置索引,更新working tree(工作樹(shù))中的不同文件,即當(dāng)前提交()代碼中與HEAD游標(biāo)所指向代碼之間的不同文件;但是合并會(huì)保留索引與working tree之間的差異部分(例如那些沒(méi)有被追蹤的修改)。

  1. $ git checkout -b <SHA>

當(dāng)然,Git中總是有其他的實(shí)現(xiàn)辦法,你可以查看看這篇文章繼續(xù)了解。

6. 從當(dāng)前Git分支移除未追蹤的本地文件

假設(shè)你湊巧有一些未被追蹤的文件(因?yàn)椴辉傩枰鼈儯?,不想每次使?code>git status命令時(shí)讓它們顯示出來(lái)。下面是解決這個(gè)問(wèn)題的一些方法:

$ git clean -f -n         # 1
$ git clean -f            # 2
$ git clean -fd           # 3
$ git clean -fX           # 4
$ git clean -fx           # 5

  • (1): 選項(xiàng)-n將顯示執(zhí)行(2)時(shí)將會(huì)移除哪些文件。

  • (2): 該命令會(huì)移除所有命令(1)中顯示的文件。

  • (3): 如果你還想移除文件件,請(qǐng)使用選項(xiàng)-d。

  • (4): 如果你只想移除已被忽略的文件,請(qǐng)使用選項(xiàng)-X。

  • (5): 如果你想移除已被忽略和未被忽略的文件,請(qǐng)使用選項(xiàng)-x。

請(qǐng)注意***兩個(gè)命令中X的區(qū)別。

更多詳情,請(qǐng)查看官方文檔中關(guān)于git-clean的介紹。 

7. 刪除本地和遠(yuǎn)程Git分支

刪除本地分支:

  1. $ git branch --delete --force <branchName>

或者使用選項(xiàng)-D作為簡(jiǎn)寫(xiě):

  1. $ git branch -D

刪除遠(yuǎn)程分支:

  1. $ git push origin --delete <branchName>

建議:要想更好地掌握Git的用法,請(qǐng)仔細(xì)閱讀Git官方文檔。

 

來(lái)源:編程派    原文:https://medium.freecodecamp.com/7-git-hacks-you-just-can-t-ignore-41aea137727a 作者: Ritesh Shrivastav
譯文:http://www.codingpy.com/article/seven-git-hacks-you-just-cannot-ignore/

責(zé)任編輯:王雪燕 來(lái)源: 編程派
相關(guān)推薦

2020-12-07 09:56:34

GitLinux版本控制系統(tǒng)

2021-06-28 11:46:31

GitLinux

2021-08-17 10:08:44

HTML網(wǎng)站網(wǎng)絡(luò)

2021-11-22 12:13:54

Linuxwget 命令

2023-08-22 10:25:19

CSS動(dòng)畫(huà)網(wǎng)頁(yè)

2024-03-12 10:02:31

Python內(nèi)存編程

2022-12-12 13:19:11

Vue3開(kāi)發(fā)技巧

2023-03-19 16:02:33

JavaScrip技巧編程語(yǔ)言

2023-09-07 16:28:46

JavaScrip

2019-08-30 12:01:48

2023-05-30 09:59:38

2018-05-24 08:47:15

數(shù)據(jù)存儲(chǔ)技巧

2024-06-25 15:41:41

2022-04-14 10:40:11

領(lǐng)導(dǎo)者IT團(tuán)隊(duì)遠(yuǎn)程團(tuán)隊(duì)

2011-03-02 09:34:58

AppFuse

2023-11-06 11:32:46

CSS選擇器作用域

2019-09-09 10:32:51

基于意圖的網(wǎng)絡(luò)IBN網(wǎng)絡(luò)

2022-09-25 22:56:52

JavaScrip編程技巧

2016-03-04 10:18:24

xcode技巧開(kāi)發(fā)

2016-03-04 10:25:50

Xcode技巧開(kāi)發(fā)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)