「这是我参与2022首次更文挑战的第6天,活动详情查看:2022首次更文挑战」。
Git使用
创建版本库
面试官: 什么是版本库?
码农: 什么是版本库呢?版本库又名仓库,英文名repository。其实你可以理解成一个目录,这个目录厘米啊吗的所有文件都可以被Git管理起来,每个文件的修改、删除,Git都能跟踪,因此可以在任意时刻追踪历史,或者在将来任意时刻进行“还原”。
面试官: 你可以现场演示一下怎么创建版本库吗?
码农: 当然没有问题。
码农: 创建版本库是很简单的,首先我们需要创建一个文件夹。
$ mkdir git-demo $ cd git-demo $ pwd /Users/kangjialv/Documents/git-demo
pwd
命令用于显示当前目录。接下来,我们通过git init
命令把这个目录变成Git可以管理的仓库。
$ git init hint: Using 'master' as the name for the initial branch. This default branch name hint: is subject to change. To configure the initial branch name to use in all hint: of your new repositories, which will suppress this warning, call: hint: hint: git config --global init.defaultBranch <name> hint: hint: Names commonly chosen instead of 'master' are 'main', 'trunk' and hint: 'development'. The just-created branch can be renamed via this command: hint: hint: git branch -m <name> Initialized empty Git repository in /Users/kangjialv/Documents/git-demo/.git/
看到Initialized empty Git repository in /Users/kangjialv/Documents/ git-demo/.git/
这段话时,证明仓库已经创建成功了。此时默认在仓库中默认创建.git
的目录,这个目录是Git来跟踪管理版本库(没事千万不要动,没事千万不要动,没事千万不要动)。.git
目录默认是隐藏的,如果看不到也不用着急奥。Windows用户可以打开隐藏文件显示设置,linux和Mac用户可以ls -ah
让目录可见哟。
添加文件到版本库
面试官: 你知道版本控制系统可以跟踪哪些类型文件的改动吗?
码农: 这个太简单了吧。所有的版本控制系统,其实只能跟踪文本文件的改动,比如.txt、.java、.html等,Git当然也不例外。版本控制系统可以告诉你每次的改动,比如在第一行加了一个"hello world"字符串,在最后一行删除了一个分号。而图片、视频等这些二进制文件,虽然也能有版本控制系统管理,但并没有办法跟踪文件的变化。只知道一个图片从100k改成了1M,但是并不知道图片究竟改了什么。
面试官: 那你可以演示一下怎么添加文件到版本库吗?
码农: 可以,首先我们创建一个在刚刚初始化的仓库中,创建一个Readme.md文件。
然后在里面输入hello world
$ touch readme.md $ echo "hello world" > readme.md $ cat readme.md hello world
可以看到此时我们已经创建了readme.md文件并在里面输入了一段话。
和把大象放到冰箱需要3步相比,把一个文件放到Git仓库只需要两步。
第一步,用命令git add
告诉Git,把文件添加到仓库:
$ git add readme.txt
执行上面的命令,没有任何显示,这就对了,Unix的哲学是“没有消息就是好消息”,说明添加成功。
第二步,用命令git commit
告诉Git,把文件提交到仓库:
$ git commit -m "add readme.md" [master (root-commit) a21a424] add readme.md 1 file changed, 1 insertion(+) create mode 100644 readme.md
git commit
命令执行成功后会告诉你,1 file changed
:1个文件被改动(我们新添加的readme.txt文件);2 insertions
:插入了两行内容(readme.txt有两行内容)。
为什么Git添加文件需要add
,commit
一共两步呢?因为commit
可以一次提交很多文件,所以你可以多次add
不同的文件,比如:
$ git add demo1.txt $ git add demo2.txt demo3.txt $ git commit -m "add 3 files."