Git学习笔记(三)

@

常规操作

1. 版本回退

要将 Git 存储库版本回退,请使用 git reset 命令。如果您想要撤消上次提交并返回到上一个提交,则可以使用以下命令:

1
git reset HEAD~1

这将使 HEAD 指向上一个提交,但不会删除您最新的更改。如果您希望完全返回到以前的提交并放弃所有更改,则可以添加–hard 选项:

1
git reset --hard HEAD~1

请注意,此操作将永久删除您最新的更改,请谨慎使用。如果您已经将更改推送到远程存储库,则在执行此操作之前应先备份这些更改。

2. 理解工作区与暂存区的区别

Git 有三个主要的工作区域:工作区(working directory)、暂存区(staging area)和版本库(repository)

工作区是指您电脑文件系统上用于修改文件的目录。在这里,您可以创建、编辑和删除文件。

暂存区是一个中间状态,它充当了您提交更改的缓冲区。在 Git 中,您必须明确地将文件添加到暂存区,然后才能将其提交到版本库中。这样做的好处是,您可以对每个更改进行精细控制,并确保只提交需要保存的更改。

版本库包含 Git 存储库的所有历史记录和元数据。它是 Git 存储库的核心组成部分,是由 Git 自动维护的。

简而言之,工作区是您正在处理的实际文件,而暂存区是下一次提交所需更改的文件列表。它们之间的区别在于,您可以对工作区中的任何文件进行修改,但只有将它们添加到暂存区并将其提交到版本库中,它们才会成为 Git 跟踪的部分。

3. Git 撤销修改和删除文件操作

要撤销对文件的修改,可以使用 git checkout 命令:

1
git checkout -- <filename>

此命令将覆盖工作树中指定文件的更改,还原为最近提交或上次检出的状态。

要删除文件并将此更改提交到 Git 存储库中,可以使用 git rm 命令:

1
2
git rm <filename>
git commit -m "Remove file"

这将从工作树和版本历史记录中删除指定的文件。如果只是想从 Git 版本库中删除文件但保留在工作树中,则可以使用 git rm 命令的–cached 选项:

1
2
git rm --cached <filename>
git commit -m "Remove file from repository"

这将从版本历史记录中删除指定的文件,但保留在工作树中。