Git 仓库
什么是仓库呢? 英文名repository,您可以简单理解成一个目录,这个目录里面的所有文件都可以被 Git 管理起来,每个文件的修改、删除, Git 都能跟踪,以便任何时刻都可以追踪历史,或者在将来某个时刻可以“还原”。
初始化仓库
创建一个仓库非常简单,首先,选择一个合适的地方,创建一个空目录:
# open shell (PowerShell on Windows) in a proper directory
$ mkdir learngit
$ cd learngit
$ pwd
/users/hope-studio/learngit
pwd
命令用于显示当前目录。
提示
- 使用 Windows 系统时,为了避免遇到各种莫名其妙的问题,请确保目录名(包括父目录)不包含中文。
- 为了确保能够执行跨平台的命令,请在 Windows 上安装 PowerShell 并设置为 VS Code 的默认终端。
第二步,通过 git init
命令把这个目录变成 Git 可以管理的仓库:
$ git init
Initialized empty Git repository in /users/hope-studio/learngit/.git/
瞬间 Git 就把仓库建好了,而且告诉您是一个空的仓库(empty Git repository),可以发现当前目录下多了一个.git 的目录,这个目录是 Git 来跟踪管理仓库的,如果这个目录里面的文件破坏了,Git 仓库也破坏了。
如果您没有看到 .git 目录,那是因为这个目录默认是隐藏的,用 ls -ah
命令就可以看见。
也不一定必须在空目录下创建 Git 仓库,选择一个已经有东西的目录也是可以的。
警告
请不要用已经在使用的项目练习 Git!
把文件添加到仓库
首先这里再明确一下,所有的版本控制系统,其实只能跟踪文本文件的改动,比如 TXT 文件,网页,所有的程序代码等等,Git 也不例外。版本控制系统可以告诉您每次的改动,比如在第 5 行加了一个单词“Linux”,在第 8 行删了一个单词“Windows”。而图片、视频这些二进制文件,虽然也能由版本控制系统管理,但没法跟踪文件的变化,只能把二进制文件每次改动串起来,也就是只知道图片从 100KB 改成了 120KB,但到底改了啥,版本控制系统不知道,也没法知道。(Microsoft 的 Word 格式是二进制格式,所以很不幸) 所以要使用版本控制系统,就要以纯文本方式编写文件。
提示
因为文本是有编码的,比如中文有常用的 GBK 编码,日文有 Shift_JIS 编码,如果没有历史遗留问题,强烈建议使用标准的 UTF-8 编码,所有语言使用同一种编码,既没有冲突,又被所有平台所支持。
注意
千万不要使用 Windows 自带的记事本编辑任何文本文件。
现在编写一个 readme.txt 文件,内容如下:
Git is a version control system.
Git is free software.
一定要放到 learngit
目录下(子目录也行),因为这是一个 Git 仓库,放到其他地方 Git 再厉害也找不到这个文件。
把一个文件放到 Git 仓库只需要两步:
用命令
git add
告诉 Git,把文件添加到仓库:git add readme.txt
执行上面的命令,没有任何显示,这就对了,Unix 的哲学是“没有消息就是好消息”,说明添加成功。
用命令
git commit
告诉 Git,把文件提交到仓库:$ git commit -m "wrote a readme file" [master (root-commit) eaadf4e] wrote a readme file 1 file changed, 2 insertions(+) create mode 100644 readme.txt
git commit
命令,-m
后面输入的是本次提交的说明,这样您就能从历史记录里方便地找到改动记录。git commit
命令执行成功后会告诉您,1 file changed
: 1 个文件被改动(我们新添加的 readme.txt 文件);2 insertions
: 插入了两行内容(readme.txt 有两行内容)。
为什么 Git 添加文件需要 add
,commit
一共两步呢? 因为 commit
可以一次提交很多文件,所以您可以多次 add
不同的文件,比如:
git add file1.txt
git add file2.txt file3.txt
git commit -m "add 3 files."
小结
初始化一个 Git 仓库,使用
git init
命令。添加文件到 Git 仓库,分两步:
- 使用命令
git add <file>
,可反复多次使用,添加多个文件; - 使用命令
git commit -m <message>
,完成。
- 使用命令