二、Git入門與基本使用(2)-創(chuàng)新互聯(lián)

6、給文件重命名的簡便方法

創(chuàng)新互聯(lián)成立于2013年,是專業(yè)互聯(lián)網(wǎng)技術服務公司,擁有項目做網(wǎng)站、成都網(wǎng)站設計網(wǎng)站策劃,項目實施與項目整合能力。我們以讓每一個夢想脫穎而出為使命,1280元黃島做網(wǎng)站,已為上家服務,為黃島各地企業(yè)和個人服務,聯(lián)系電話:13518219792

使用: git move 命令可以給暫存區(qū)中的文件重命名

$ git mv first.txt first.md

$ git status
On branch master
Changes to be committed:
  (use "git reset HEAD <file>..." to unstage)

        renamed:    first.txt -> first.md

$ git commit -m"move first.txt to first.md"
[master 5d63d93] move first.txt to first.md
 1 file changed, 0 insertions(+), 0 deletions(-)
 rename first.txt => first.md (100%)

7、通過git log 查看版本演變歷史

$ git log --oneline --graph        #圖形化方式,簡潔顯示日志
* 7376bc5 (HEAD -> temp) Update fourth file
* 1d63ec8 Add fouth file
* b843c28 Add third file
* 0bd98cb Add second file
* c8588e4 Add first file

$ git log --oneline --graph --all    #顯示所有分支日志
* 5d63d93 (master) move first.txt to first.md
* 7376bc5 (HEAD -> temp) Update fourth file
* 1d63ec8 Add fouth file
* b843c28 Add third file
* 0bd98cb Add second file
* c8588e4 Add first file

$ git log --oneline --graph --all -n3    #指定顯示日志數(shù)量
* 5d63d93 (master) move first.txt to first.md
* 7376bc5 (HEAD -> temp) Update fourth file
* 1d63ec8 Add fouth file

8、.gitk:通過圖形界面工具來查看版本歷史
 gitk 是 git 提供的一個gui工具,可以很清晰地查看搜索提交歷史及 git 相關操作。在終端 git 倉庫目錄下輸入 gitk 命令即可使用。
二、Git入門與基本使用(2)

詳細實用可參考連接:Use gitk to understand git

9、.git目錄中各文件的含義

$ ls .git/ -l
total 14
-rw-r--r-- 1 nxf42573 1049089  27 Mar 15 17:46 COMMIT_EDITMSG
-rw-r--r-- 1 nxf42573 1049089 130 Mar 14 16:34 config
-rw-r--r-- 1 nxf42573 1049089  73 Mar 14 16:34 description
-rw-r--r-- 1 nxf42573 1049089 298 Mar 15 17:55 gitk.cache
-rw-r--r-- 1 nxf42573 1049089  21 Mar 15 17:50 HEAD
drwxr-xr-x 1 nxf42573 1049089   0 Mar 14 16:34 hooks/
-rw-r--r-- 1 nxf42573 1049089 369 Mar 15 17:50 index
drwxr-xr-x 1 nxf42573 1049089   0 Mar 14 16:34 info/
drwxr-xr-x 1 nxf42573 1049089   0 Mar 14 16:36 logs/
drwxr-xr-x 1 nxf42573 1049089   0 Mar 15 17:46 objects/
drwxr-xr-x 1 nxf42573 1049089   0 Mar 14 16:34 refs/

.git 文件的結構 The .git Directory
二、Git入門與基本使用(2)

文件 類型 內容 作用
config文本文件見上圖本地git存儲庫的配置文件
HEAD文件夾ref: refs/heads/master當前分支,即 git branch 命令顯示的分支
refs/heads文件夾-本地庫所有的分支
refs/heads/master文本文件6975b…master 分支最近一次 commit 的 SHA1 值
refs/heads/v1文本文件fd70…v1 分支最近一次 commit 的 SHA1 值
refs/remotes文件夾-refs/remotes目錄下的所有內容都是對遠程跟蹤分支的提交的引用。
refs/remotes/origin文件夾-遠程存儲庫源的遠程跟蹤分支存儲在這個目錄中。
COMMIT_EDITMSG文本文件“some commit description”最后一次 commit 的注釋
hooks文件夾-這個目錄存放一些shell腳本,可以設置特定的git命令后觸發(fā)相應的腳本
info文件夾-包含git倉庫的一些信息
logs文件夾-保存所有更改的引用記錄,繼續(xù)打開logs文件夾,有refs文件夾和HEAD文件

10、commit、tree和blob三個對象之間的關系
git中文版
 每個對象(object) 包括三個部分:類型,大小和內容。大小就是指內容的大小,內容取決于對象的類型,有四種類型的對象:"blob"、"tree"、 "commit" 和"tag"。
 “blob”用來存儲文件數(shù)據(jù),通常是一個文件。
 “tree”有點像一個目錄,它管理一些“tree”或是 “blob”(就像文件和子目錄)
 一個“commit”只指向一個"tree",它用來標記項目某一個特定時間點的狀態(tài)。它包括一些關于時間點的元數(shù)據(jù),如時間戳、最近一次提交的作者、指向上次提交(commits)的指針等等。
Blob對象
 一個blob通常用來存儲文件的內容,"blob對象"就是一塊二進制數(shù)據(jù),它沒有指向任何東西或有任何其它屬性,甚至連文件名都沒有.因為blob對象內容全部都是數(shù)據(jù),如兩個文件在一個目錄樹(或是一個版本倉庫)中有同樣的數(shù)據(jù)內容,那么它們將會共享同一個blob對象。Blob對象和其所對應的文件所在路徑、文件名是否改被更改都完全沒有關系。
二、Git入門與基本使用(2)

$ git show 6ff87c4664
 Note that the only valid version of the GPL as far as this project
 is concerned is _this_ particular version of the license (ie v2, not
 v2.2 or v3.x or whatever), unless explicitly otherwise stated.
...

Tree 對象
 一個tree對象有一串指向blob對象或是其它tree對象的指針,它一般用來表示內容之間的目錄層次關系。一個tree對象可以指向(reference): 一個包含文件內容的blob對象, 也可以是其它包含某個子目錄內容的其它tree對象。 Tree對象、blob對象和其它所有的對象一樣,都用其內容的SHA1哈希值來命名的;只有當兩個tree對象的內容完全相同(包括其所指向所有子對象)時,它的名字才會一樣,反之亦然。這樣就能讓Git僅僅通過比較兩個相關的tree對象的名字是否相同,來快速的判斷其內容是否不同。

$ git ls-tree fb3a8bdd0ce
100644 blob 63c918c667fa005ff12ad89437f2fdc80926e21c    .gitignore
100644 blob 5529b198e8d14decbe4ad99db3f7fb632de0439d    .mailmap
100644 blob 6ff87c4664981e4397625791c8ea3bbb5f2279a3    COPYING
040000 tree 2fb783e477100ce076f6bf57e4a6f026013dc745    Documentation
100755 blob 3c0032cec592a765692234f1cba47dfdcc3a9200    GIT-VERSION-GEN
100644 blob 289b046a443c0647624607d471289b2c7dcd470b    INSTALL
100644 blob 4eb463797adc693dc168b926b6932ff53f17d0b1    Makefile
100644 blob 548142c327a6790ff8821d67c2ee1eff7a656b52    README
...

Commit對象
"commit對象"指向一個"tree對象", 并且?guī)в邢嚓P的描述信息。
二、Git入門與基本使用(2)

$ git show -s --pretty=raw 0bd98cb5d0d969cfc35
commit 0bd98cb5d0d969cfc35d8c5a16d33b5924cbc6b0
tree c1cf819308e03d9a2236f8ab2d0c7f5c6587d32f
parent c8588e43dd1053684632871fb8aec1945ee6a6ab
author Jone <764651475@qq.com> 1552553965 +0800
committer Jone <764651475@qq.com> 1552553965 +0800

    Add second file

 一個 tree對象: tree對象的SHA1簽名, 代表著目錄在某一時間點的內容.
 父對象 (parent(s)): 提交(commit)的SHA1簽名代表著當前提交前一步的項目歷史. 上面的那個例子就只有一個父對象; 合并的提交(merge commits)可能會有不只一個父對象. 如果一個提交沒有父對象, 那么我們就叫它“根提交"(root commit), 它就代表著項目最初的一個版本(revision). 每個項目必須有至少有一個“根提交"(root commit). 一個項目可能有多個"根提交“,雖然這并不常見(這不是好的做法).
 作者 : 做了此次修改的人的名字, 還有修改日期.
 提交者(committer): 實際創(chuàng)建提交(commit)的人的名字, 同時也帶有提交日期. TA可能會和作者不是同一個人; 例如作者寫一個補丁(patch)并把它用郵件發(fā)給提交者, 由他來創(chuàng)建提交(commit).
 注釋 用來描述此次提交.

另外有需要云服務器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。

網(wǎng)頁題目:二、Git入門與基本使用(2)-創(chuàng)新互聯(lián)
文章源于:http://muchs.cn/article4/cdsgie.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供移動網(wǎng)站建設手機網(wǎng)站建設、外貿網(wǎng)站建設、電子商務、微信小程序、Google

廣告

聲明:本網(wǎng)站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

微信小程序開發(fā)