成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

學(xué)會這三個命令,你就不再是git只會用三板斧的菜鳥了

開發(fā) 前端
今天我們來介紹幾個git當(dāng)中常用并且重要的命令,它們分別是git diff,查看提交歷史的git log。

 前言

在之前的文章當(dāng)中我們介紹了最基本的git add、git commit和git push的用法以及基本原理,還介紹了gitignore文件的設(shè)置方法,從而讓我們可以使用git add .來添加我們想要的文件,而不必要手動區(qū)分。

今天我們繼續(xù)來介紹幾個git當(dāng)中常用并且重要的命令,它們分別是git diff,查看提交歷史的git log。

git diff

git diff是一個非常好用的命令,很多大牛都用它查看代碼的改動,因為它的確非常方便。git diff命令可以查看當(dāng)前工作區(qū)與暫存區(qū)的差別,也就是說可以查看到當(dāng)前我們修改或者是添加的,但是還沒有add進暫存區(qū)的代碼。它會列出改動前后的對比,方便我們進行查看和修改。

比如我隨便找了個repo運行了一下git diff,后面沒有加上任何參數(shù),我從結(jié)果當(dāng)中截取了一個片段如下:

學(xué)會這三個命令,你就不再是git只會用三板斧的菜鳥了

由于我配置了zsh,它會高亮顯示修改前后的內(nèi)容對比。比如在上面這個例子當(dāng)中,我們刪除了一行,添加了兩行。我們可以很方便地查看前后的改動,方便我們檢查修改的邏輯是否有出錯。

git diff + 文件路徑

當(dāng)然git diff如果不加任何參數(shù)的話,會默認(rèn)展示所有的文件改動,有時候我們改動的量比較大,看起來也會比較累。這個時候我們可以加上文件名,查看一下某一個文件具體的改動。比如上面例子當(dāng)中的改動,發(fā)生在一個shell文件當(dāng)中,我可以直接運行g(shù)it diff shell/prepare_data.sh,也就是這個shell文件對應(yīng)的路徑,會發(fā)現(xiàn)其他的改動都看不到了。

學(xué)會這三個命令,你就不再是git只會用三板斧的菜鳥了

git diff --cached

前面說了,我們在不加任何參數(shù)的情況下查看的是工作區(qū)(add命令之前)的代碼和暫存區(qū)的差別,如果我們已經(jīng)把所有代碼都add進來了,那么當(dāng)我們運行g(shù)it diff是不會顯示任何東西的。比如我們在剛才的倉庫先把所有代碼提交一下,再來運行g(shù)it diff結(jié)果如下:

學(xué)會這三個命令,你就不再是git只會用三板斧的菜鳥了

可以看到剛才所有的改動都沒了,這是因為我們已經(jīng)把代碼提交到暫存區(qū)了,不加參數(shù)的時候是比較的工作區(qū)和暫存區(qū)的差別。這個時候我們再想看diff,想看的其實是暫存區(qū)和本地git倉庫的差別,也就是已經(jīng)add了還沒commit的改動。這個時候我們可以通過--cached參數(shù)來實現(xiàn),--cached參數(shù)后面同樣可以再跟上文件名,查看某一個具體的文件。

比如當(dāng)我們執(zhí)行g(shù)it diff --cached shell/prepare_data.sh之后,剛才的改動就又重新展示出來了。

學(xué)會這三個命令,你就不再是git只會用三板斧的菜鳥了

其他用法

除了剛才提到的方法之外,git diff還有一些其他的用法。比如還可以和一個確定的提交,另外一個分支進行比較。這些命令相對不太常用,我們簡單列舉一下:

  1. # 比較工作區(qū)和某一個提交的差別 
  2. git diff <commitid> 
  3.  
  4. # 比較工作區(qū)和某一個提交某一個文件的差別 
  5. git diff <commitid> <filepath> 
  6.  
  7. # 比較暫存區(qū)和某一個提交的差別 
  8. git diff --cached <commitid> 
  9.  
  10. # 比較暫存區(qū)和某一個提交某一個文件的差別 
  11. git diff --cached <commitid> <filepath> 

git log

git log大家可能有所耳聞,即使沒有也不難從名字當(dāng)中猜出用途,它可以展示出當(dāng)前分支上所有的提交。

比如當(dāng)我在存放git文章的repo下運行g(shù)it log,就可以查看到之前的提交記錄:

學(xué)會這三個命令,你就不再是git只會用三板斧的菜鳥了

log當(dāng)中有兩處比較重要的信息,我都用紅筆高亮了出來。其中一個是commit后面跟著的一長串,這個是commit id,它在git倉庫當(dāng)中是唯一的,我們可以用它來鎖定一個commit。比如剛才上面提到的git diff和某一個commit比較,傳入的commitid就是這個。

我們沒必要復(fù)制全部的id,因為太長了,實際上git有自動補全功能,我們一般復(fù)制前面幾位就可以了。比如git diff dfd55就足夠了,git會根據(jù)我們輸入的幾位查找到符合條件的commit,一般來說前幾位就足夠鎖定一個commit了。

第二個關(guān)鍵信息就是提交信息,也就是我們每次commit -m之后后面輸入的字符串,也就是表示這個commit當(dāng)中的改動改動了什么,這個是開發(fā)者寫的,也是比較關(guān)鍵的提示信息。

git log -p

當(dāng)我們運行g(shù)it log的時候只會展示提交相關(guān)的信息,是不會把每一次改動的內(nèi)容都展示出來的,一則沒有必要,二則未免太多了。但是有的時候我們會希望看到每一個commit當(dāng)中改動的究竟是什么,如果通過git diff一個一個查看也太麻煩了。這個時候就可以用上參數(shù)來實現(xiàn)這點,只需要在git log后面加上-p,它就會展示出每一個commit中的改動

學(xué)會這三個命令,你就不再是git只會用三板斧的菜鳥了

其實我們從頭部的日志信息也可以看得出來,它底層也是通過git diff實現(xiàn)的。由于commit當(dāng)中的改動量可能很大,所以我們這樣查看到的內(nèi)容也會非常多。我們可以在-p后面再加上一個-n表示我們想要查看的最近幾條commit信息,比如git log -p -2查看的就是最近兩條提交信息。

git log --stat

有的時候(比如HR根據(jù)代碼確定績效)我們只是想要查看每一次commit到底有多少改動量,而不想知道具體的改動是什么,這個時候就可以使用stat參數(shù)。

它會告訴我們這個commit中每一個文件做的改動有多少,方便我們查看具體到文件的變更。

學(xué)會這三個命令,你就不再是git只會用三板斧的菜鳥了

git log --pretty

pretty這個參數(shù)是一個神器,它可以支持讓我們自己diy我們想要看到的log展示。比如常用的是git log --pretty=oneline,這里的oneline是一種格式,表示單行展示,也就是會把commit展示的信息壓縮成一行。

學(xué)會這三個命令,你就不再是git只會用三板斧的菜鳥了

我們可以看到它省略了author、時間等信息,僅僅保留了commitid和comment信息。這種一般用在排查問題的時候,想要快速找到某一個commit。除了oneline之外,官方還提供了其他幾種format,比如short、full、fuller這三種,這三者展示的信息略有差別,大家可以自行嘗試一下。

最后介紹一種牛叉的用法,就是我們自己來定義我們想要的輸出結(jié)果。舉個例子,比如我想要看到的log日志當(dāng)中應(yīng)該包含commitid,提交時間,作者以及comment。那么我們就可以自己定義出一種格式:%h - %ad - %an - %s。這樣我們執(zhí)行的命令就是:

git log --pretty=format:"%h - %ad - %an - %s" 

得到的結(jié)果會是:

學(xué)會這三個命令,你就不再是git只會用三板斧的菜鳥了

這正是我們想要的,這里的%h, %ad其實也是官方提供的參數(shù),他們分別表示一種信息。比如%h表示短commitid,%ad表示提交時間,%an表示作者信息,%s表示提交時的comment。當(dāng)然可選的參數(shù)不止這些,官方提供了一個表格,表格當(dāng)中的參數(shù)都可以選擇。

學(xué)會這三個命令,你就不再是git只會用三板斧的菜鳥了

git log還有一種參數(shù)的用法是--graph,可以展示出提交的一個樹形分支結(jié)構(gòu)。也是非常非常好用的,但是我找不到合適的repo展示,所以用一個官方的例子展示給大家:

學(xué)會這三個命令,你就不再是git只會用三板斧的菜鳥了

除了上面介紹的功能之外,git log還有一些其他的功能,相對來說不是很常用,就不贅述了。感興趣的同學(xué)可以去查看一下官方文檔,體會一下git命令的強大。

總結(jié)

怎么樣,今天介紹的git diff和git log命令都學(xué)會了嗎,是不是有一種看起來簡單其實學(xué)起來還挺復(fù)雜的感覺?其實是非常正常的,因為git是面向所有開發(fā)者的,不同的開發(fā)者有不同的習(xí)慣,總有些人有些自己特殊的需求。所以git也就被設(shè)計的非常復(fù)雜和強大,可以實現(xiàn)各種功能,我們也沒必要全部學(xué)會,根據(jù)日常的需要進行取舍,一部分重點學(xué)習(xí),其他的泛泛了解即可。

 

責(zé)任編輯:張燕妮 來源: 今日頭條
相關(guān)推薦

2013-07-03 11:13:58

DevOps

2011-03-09 15:23:25

Windows Ser

2014-07-29 11:25:18

LinuxMySQL

2017-03-23 10:54:58

LINUXMYSQL優(yōu)化

2020-09-03 15:32:08

Wireshark數(shù)據(jù)包分析

2017-08-21 23:50:45

線上內(nèi)存OOM

2020-11-18 08:17:14

Java源碼Class

2009-02-19 10:20:00

2019-05-30 14:30:42

技術(shù)管理架構(gòu)

2012-11-08 16:05:23

2020-03-09 13:37:49

Serverless無服務(wù)器騰訊云

2022-07-22 09:55:29

軟件工程師

2022-05-07 11:47:36

服務(wù)器架構(gòu)

2019-08-13 16:23:19

JavaScript數(shù)組方法

2018-06-19 08:50:15

崗位總監(jiān)管理

2010-12-29 10:29:31

Linux磁盤管理dfdu

2022-03-29 18:20:10

戴爾

2019-11-14 08:34:08

LinuxMySQLCPU

2010-05-28 09:17:45

ARM服務(wù)器

2021-06-25 15:19:13

攻防演練
點贊
收藏

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

主站蜘蛛池模板: 亚洲视频不卡 | 日本三级网| 中文字幕一区在线 | 精品国产欧美一区二区三区成人 | 久久专区 | 操亚洲| 成人精品一区二区三区中文字幕 | 亚洲天堂一区 | 亚洲天堂免费在线 | 久久久久国产一区二区三区 | caoporn视频| 中文字幕av在线播放 | 免费一区二区三区在线视频 | 成人精品视频在线观看 | 国产亚洲精品久久久优势 | 国产精品久久久久久久久久久免费看 | 中国一级特黄真人毛片免费观看 | 欧美在线观看一区 | 男女网站免费观看 | 免费天天干 | 一区二区三区欧美 | 免费观看国产视频在线 | 日日欧美 | 四虎最新视频 | 日韩一二区 | 日韩成人在线播放 | 国产91精品网站 | 国产日韩欧美精品 | 毛片网站免费观看 | 久久久精品一区二区 | 精品国产鲁一鲁一区二区张丽 | 亚洲国产精品网站 | 黄色一级免费 | 国产精品一区二区三区四区 | 精品综合| 久久精品一区二区 | 午夜免费视频 | 亚洲精品电影在线 | 91久久网站| 91在线观看| 国产在线一区二区三区 |