操作文件

获取或者创建本地Git仓库这篇文章使用了gitsample作为示例介绍了如何从Git服务器获取本地仓库。本文将继续使用这个项目作为示例。
本文将介绍下列命令的常见用法:

git add
git status
git diff
git commit

1. Git本地仓库的结构

1.1. 本地仓库的组成

一个典型的Git仓库是由工作区(Working Tree,之前也被称之为Working directory)、暂存区和版本库(Repository)组成的。下图是一个典型的Git仓库结构图:


图-1 Git仓库结构

以gitsample仓库为例,它的文件夹目录文件树结构如下所示:

gitsample
└─.git
│  └─...
│  └─objects
│  ├─index
│  ├─HEAD
└─workspace
│  ├─index.php
├─demo_status.txt
├─README.md

工作区顾名思义,我们的工作文件都存放在这个区域。gitsample目录下面所有的用户目录和文件都属于工作区内容;
暂存区在早前git版本也被称为缓存区,暂存区的内容就是预期的下一次的提交,也就是提交时需要git写入到版本库的内容。将文件添加到暂存区的动作可以简单的理解为另存了文件的快照,也就是git复制了当前文件的内容然后粘贴到暂存区保存为副本。.git文件夹内有一个名为index的文件,此文件就是暂存区文件的索引(索引指向的文件的快照是存放在objects目录的)。可以使用git ls-files命令查看暂存区的文件列表;
版本库存放的是版本历史。每次提交都会产生一个新的版本,最近一次版本的commit id(SHA-1哈希值)存放在HEAD文件中。沿着最近一次的版本可以一直向前追溯到初始的版本。

1.2. 工作区文件的生命周期

在Git中,工作区的文件状态是有生命周期变化的。如下图所示:


文件的生命周期状态变化

1). 在项目工作区新建的文件,其状态为Untracked(未追踪);
2). 对于状态处于1)或4)的文件,将其添加到暂存区后其状态变为Staged(已暂存,等待提交);
3). 对于状态处于2)的文件, 将其提交到版本库后其状态变为Unmodified(亦即已提交);
4). 当文件被修改后其状态变为Modified(已修改)。

2. git add 向暂存区添加文件的快照

假如工作区新建了一个add_demo.txt文件,此时使用下面的方式将文件添加到暂存区:
git add add_demo.txt:只将add_demo.txt文件的快照添加到暂存区
git add *.txt:将所有txt文件快照添加到暂存区
git add .:将所有文件的快照添加到暂存区

3. git status 查看工作区和暂存区、暂存区和版本库的文件状态变化

新建add_demo.txt文件尚未添加到暂存区时:

$ git status
On branch master
Your branch is up to date with 'origin/master'.

Untracked files:
  (use "git add <file>..." to include in what will be committed)

        add_demo.txt

nothing added to commit but untracked files present (use "git add" to track)

可以看到git检测到工作目录中有未追踪的文件。接下来执行git add .命令将文件添加到暂存区后再来查看状态:

$ git status
On branch master
Your branch is up to date with 'origin/master'.

Changes to be committed:
  (use "git reset HEAD <file>..." to unstage)

        new file:   add_demo.txt

从命令的执行结果可以看到文件现在已经是等待提交状态了。

4. git diff 比较文本内容差异

git diff:比较工作区的文件和暂存区文件的差异。git diff只会比较已经暂存过的文件。例如,我们在工作区新增add_demo.txt文件并在文件中保存一段文字“this is a demo file for file staging.”,此时使用git diff命令是不会比较这个文件的;当此文件添加到暂存区后,我们再来修改这个文件在里面新加一行文字“Git diff should work and show the difference this time.”并保存,再使用git diff来比较就可以看到暂存区和工作区的文件内容差异了:

$ git diff
diff --git a/add_demo.txt b/add_demo.txt
index fe17f7f..df7cefe 100644
--- a/add_demo.txt
+++ b/add_demo.txt
@@ -1 +1,2 @@
-this is a demo file for file staging.
\ No newline at end of file
+this is a demo file for file staging.
+Git diff should work and show the difference this time.
\ No newline at end of file

git diff --staged:比较暂存区的文件和最近一次提交版本的差异。此命令不会比较被添加到暂存区但从未被提交到版本库的文件。
git diff --stat:显示差异的简要统计信息。例如:

$ git diff --stat
 add_demo.txt | 3 ++-
 1 file changed, 2 insertions(+), 1 deletion(-)

5. git commit 将暂存区的内容提交到版本库

git commit -m "message"命令会将暂存区内的所有文件提交到版本库,并且git会为此次提交生成一个commit id。这个commit id是一个40位长度SHA-1哈希值,用于全球唯一标识一次提交。

$ git commit -m "add_demo.txt"
[master e435501] add_demo.txt
 1 file changed, 3 insertions(+)
 create mode 100644 add_demo.txt

提交命令运行结果中有一段“[master e435501] add_demo.txt”,其中e435501就是这次提交的commit id前7位,又被称为短commit id。一般来说前7位就足以全局表示一次提交了。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,372评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,368评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,415评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,157评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,171评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,125评论 1 297
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,028评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,887评论 0 274
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,310评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,533评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,690评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,411评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,004评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,659评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,812评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,693评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,577评论 2 353