1.git的作用和概念
方便多人协作以及个人开发项目中回滚到之前的代码。
AcWing给国内用户提供了一个可靠稳定的代码托管平台:http://git.acwing.com
git的几个概念:
- 工作区:仓库的目录,独立于各个分支。
- 暂存区:数据暂时存放的区域,类似于工作区写入版本库前的缓存区,独立于各个分支。
- 版本库:存放所有已经提交到本地仓库的代码版本。
- 版本结构:树结构,每个节点代表一个版本。
我们每次的改动会由工作区传给暂存区,当我们想创建一个新版本时就由暂存区移至版本库。每次创建完一个版本之后head节点就后移,并且将新版本插入版本结构。
2.git的常见命令(本地)
首先添加自己在ACgit上注册的用户名和邮箱
git config --global user.name username
git config --global user.email email
添加完之后可以在隐藏目录下看到.gitconfig文件
打开之后可以看到刚刚添加的用户名和邮箱
接下来创建一个新的项目project
mkdir project
cd project/
在当前目录下创建git项目
git init
在当前目录下创建一个readme.txt文件,并查看当前仓库的状态:
git status
上述说明尚有一个文件未被添加至暂存区中,使用下列命令添加readme.txt至暂存区 :
git add readme.txt
亦可使用:
git add .
一键添加所有红色文件至缓存区。
添加完成之后如果要完成当前版本,则执行:
git commit -m "备注信息"
将暂存区的内容保存至分支中。
修改完文件之后可以用:
git diff readme.txt
查看当前文件和暂存区的文件的区别。
使用:
git log
查看当前分支的所有版本
使用:
git reset --hard HEAD^ #回滚到上一个版本
git reset --hard HEAD^^ #回滚到上两个版本
git reset --hard HEAD~100 #回滚一百个版本
git reset --hard 版本号 #回滚到特定版本
回滚到历史版本
如果要查看head的移动路径,可以用:
git reflog
如果文件还未存放至暂存区,但是想恢复到之前的版本(暂存区存储的版本),可以使用:
git restore readme.txt
清空暂存区的版本:
git restore --staged readme.txt
3.将本地项目传至云端
创建一个ACgit用户,并打开我的项目
我们之前已经在本地创建了一个project项目了,所以点取消。
在本地找到公钥,复制。
粘贴并添加密钥
添加完成之后打开刚才创建的项目
复制下列内容
粘贴完成之后执行:
git push -u origin master
将项目上传至云端
假如不小心删除了整个项目,可以通过云端下载到各个版本
git clone ssh地址
4.分支
个人用户在开发的时候可以在主分支上开发,但是如果多人协作则需要在其他分支开发。
git checkout -b dev #创建一个名为dev的分支
git branch #查看当前的分支
如果想回到之前的目录,可以:
git checkout master
git branch
当我们想合并当前分支到主分支时,可以执行下列代码:
git merge 想合并的分支名称
这里的Fast-forward指的是快速合并,就是将head节点直接指向dev分支,而没有产生新的复制。
另外,如果我们想删除一个分支,可以:
git branch -d 分支名称
在开发过程中,往往会遇到当前分支与其他分支冲突的问题,这个时候就无法执行自动合并,需要我们人为处理冲突。
可以看到,我们新开辟了一个分支,并对其中进行了修改。同时,我们在主分支上也对其进行了不一样的修改,这就导致了冲突。
进入修改过的文档中,我们可以看到:
两次的修改被用<和=隔开了。
我们可以对其进行手动修改。
修改完之后我们可以查看一下git log
git log --pretty=oneline #将git log简化到一行展示
当我们在非主分支想提交到云端时,往往会遇到云端没有相应分支内容的错误,这个时候我们可以
在云端新建一个对应分支:
新建完之后,我们就可以在git上面看到我们新建的分支。
此外,本地的分支跟云端的分支相对独立,如果删除本地的分支,云端的分支依然存在。若想删除云端的分支,可以执行:
git push -d origin 云端分支名称
如果此时我们想将云端的分支同步到本地,则我们需要在本地新建一个分支并且将其与云端的分支关联下来。
git branch --set-upstream-to=origin/云端分支名称 本地分支名称
执行完之后将云端的内容拉到本地:
git pull
如果我们想将云端的分支合并到本地的主分支:
git pull origin 云端分支名称
5.堆栈区
假如目前突然有其他任务要处理,而我们又不想把工作区和暂存区的内容持久化,这个时候我们就可以把它们先存到堆栈中。
git stash #将当前工作区和暂存区的内容存到堆栈中
git stash pop #将当前堆栈的栈顶弹出
git stash list #查看堆栈中的内容
6.协同开发
当我们和伙伴一起开发同一个分支的时候,也许会遇到两个人修改同一个文件从而产生冲突的情况。
这个时候我们可以先把文件pull下来,在本地解决完冲突之后再提交到云端。