Git本地有三个工作区域:工作目录(Working Directory)、暂存区(Stage/Index)、资源库(Repository或Git Directory)。如果在加上远程的git仓库(Remote Directory)就可以分为四个工作区域。文件在这四个区域之间的转换关系如下:
Workspace
:工作区,就是你平时存放项目代码的地方;Index / Stage
:暂存区,用于临时存放你的改动,事实上它只是一个文件,保存即将提交到文件列表信息,一般存放在 .git 目录下的 index 文件(.git/index)中,所以我们把暂存区有时也叫作索引(index);Repository
:仓库区(或本地仓库),就是安全存放数据的位置,这里面有你提交到所有版本的数据。其中HEAD指向最新放入仓库的版本;Remote
:远程仓库,托管代码的服务器,可以简单的认为是你项目组中的一台电脑用于远程数据交换;
本地的三个区域确切的说应该是git仓库中HEAD指向的版本:
Directory
:使用Git管理的一个目录,也就是一个仓库,包含我们的工作空间和Git的管理空间。WorkSpace
:需要通过Git进行版本控制的目录和文件,这些目录和文件组成了工作空间。.git
:存放Git管理信息的目录,初始化仓库的时候自动创建。Index/Stage
:暂存区,或者叫待提交更新区,在提交进入repo之前,我们可以把所有的更新放在暂存区。Local Repo
:本地仓库,一个存放在本地的版本库;HEAD会只是当前的开发分支(branch)。
Git 分支;
使用分支意味着你可以从开发主线上分离开来,然后在不影响主线的同时继续工作。
Git分支常用命令:
# 列出所有本地分支
git branch
# 列出所有远程分支
git branch -r
# 新建一个分支,但依然停留在当前分支
git branch [branchname]
# 新建一个分支,并切换到该分支
git checkout -b [branchname]
# 切换到主分支
$ git checkout master
# 合并指定分支到当前分支
$ git merge [branchname]
# 删除分支
$ git branch -d [branchname]
# 删除远程分支
$ git push origin --delete [branchname]
$ git branch -dr [remote/branch]
如果同一个文件在合并分支时都被修改了则会引起冲突:解决的办法是我们可以修改冲突文件后重新提交!选择要保留他的代码还是你的代码!
master主分支应该非常稳定,用来发布新版本,一般情况下不允许在上面工作,工作一般情况下在新建的dev分支上工作,工作完后,比如上要发布,或者说dev分支代码稳定后可以合并到主分支master上来。
git commit提示Your branch is up-to-date with ‘origin/master’.解决方案:
如何解决error: failed to push some refs to 'xxx(远程库)'