一开始我们创建的文件夹learngit就是工作区,然后使用了git init——创建了一个空的仓库,也就是版本库,后边我们创建的文本readme.txt或者LICENSE,通过 git add readme.txt,将文件新建到暂存区,后边我们通过git commit 去提交到版本库。

huangjiaxin@hjiax2023 MINGW64 ~/learngit (master)
$ vi readme.txt //编辑文本
huangjiaxin@hjiax2023 MINGW64 ~/learngit (master)
$ vi LICENSE //新建一个任意文本
huangjiaxin@hjiax2023 MINGW64 ~/learngit (master)
$ git status //查看当前状态
On branch master
Changes not staged for commit:
(use "git add <file>..." to update what will be committed)
(use "git restore <file>..." to discard changes in working directory)
modified: readme.txt //被修改文本
Untracked files:
(use "git add <file>..." to include in what will be committed)
LICENSE //没有被添加过,无法追踪
no changes added to commit (use "git add" and/or "git commit -a")
//Git非常清楚地告诉我们,readme.txt被修改了,而LICENSE还从来没有被添加过,
所以它的状态是Untracked。
huangjiaxin@hjiax2023 MINGW64 ~/learngit (master)
$ git add readme.txt //提交文本
huangjiaxin@hjiax2023 MINGW64 ~/learngit (master)
$ git add LICENSE //提交文本
huangjiaxin@hjiax2023 MINGW64 ~/learngit (master)
$ git status //查看工作区当前状态
On branch master
Changes to be committed:
(use "git restore --staged <file>..." to unstage)
new file: LICENSE
modified: readme.txt
//所以,git add命令实际上就是把要提交的所有修改放到暂存区(Stage),
然后,执行git commit就可以一次性把暂存区的所有修改提交到分支
huangjiaxin@hjiax2023 MINGW64 ~/learngit (master)
$ git commit -m "understand how stage works"
//简单解释一下git commit命令,-m后面输入的是本次提交的说明,
可以输入任意内容,当然最好是有意义的,这样你就能从历史记录里方便地找到改动记录。
[master 696574c] understand how stage works
2 files changed, 1 insertion(+)
create mode 100644 LICENSE
//一旦提交后,如果你又没有对工作区做任何修改,那么工作区就是“干净”的:
huangjiaxin@hjiax2023 MINGW64 ~/learngit (master)
$ git status
On branch master
nothing to commit, working tree clean
本文介绍了Git的基本操作,包括创建工作区、初始化版本库、添加(readme.txt和LICENSE)文件到暂存区、查看状态、提交更改以及如何理解暂存区的工作原理。

被折叠的 条评论
为什么被折叠?



