Git之基本理论

三、基本理论

目录:工作区域、工作流程、Git分支

1.工作区域

Git本地有三个工作区域:工作目录(Working Directory)、暂存区(Stage/Index)、资源库(Repository或Git Directory)。如果再加上远程的Git仓库(Remote Directory)就可以分为四个工作区域。文件在这四个区域之间的转换关系如下:


Git的工作区域之间的转换关系
  • Workspace:工作区,就是平时存放项目代码的地方。
  • Index/Stage:暂存区,用于临时存放新的改动。事实上它只是一个文件,保存到即将提交到文件列表信息。
  • Repository:仓库区(或本地仓库),就是安全存放数据的位置。这里面有提交到所有版本的数据。其中HEAD指向最新放入仓库的版本。
  • Remote:远程仓库,托管代码的服务器。可以简单的认为是项目组中的一台电脑用于远程数据交换。

本地的三个区域,确切地说应该是Git仓库中HEAD指向的版本:


Git的仓库中的结构
  • Directory:使用Git管理的一个目录,也就是一个仓库,包含工作空间和Git的管理空间。
  • WorkSpace:需要通过Git进行版本控制的目录和文件,这些目录和文件组成了工作空间。
  • .git:存放Git管理信息的目录,初始化仓库的时候自动创建。
  • Index/Stage:暂存区,或者叫待提交更新区,在提交进入repo之前,可以把所有的更新放在暂存区。
  • Local Repo:本地仓库,一个存放在本地的版本库;HEAD会只是当前的开发分支(branch)。
  • Stash:隐藏,是一个工作状态保存栈,用于保存/恢复WorkSpace中的临时状态。

2.工作流程

①在工作目录中添加、修改文件。
②将需要进行版本管理的文件放入暂存区域。

git add .

③将暂存区域的文件提交到Git仓库。

git commit

因此,Git管理的文件有三种状态:已修改(modified)、已暂存(staged)、已提交(committed)。


Git的工作区域之间的关系

3.Git分支

分支在Git中相对较难,分支就是科幻电影里面的平行宇宙,如果两个平行宇宙互不干扰,那对现在的世界也没啥影响。不过,如果在某个时间点,两个平行宇宙合并了,就需要处理一些问题了。


Git分支示意图

Git分支中的常用指令

# 列出所有本地分支 
git branch 
# 列出所有远程分支 
git branch -r 
# 新建一个分支,但依然停留在当前分支 
git branch [branch-name] 
# 新建一个分支,并切换到该分支 
git checkout -b [branch] 
# 合并指定分支到当前分支 
$ git merge [branch] 
# 删除分支 
$ git branch -d [branch-name] 
# 删除远程分支 
$ git push origin --delete [branch-name] 
$ git branch -dr [remote/branch]

如果同一个文件在合并分支时都被修改了,则会引起冲突。解决的办法是可以修改冲突文件后重新提交。
master主分支应该非常稳定,用来发布新版本,一般情况下不允许在上面工作。一般情况下在新建的dev分支上工作。工作完后,比如要上新发布,或者说dev分支代码稳定后,可以合并到主分支master上来。

你可能感兴趣的:(Git之基本理论)