AcWing-Linux基础课-5.git

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下来,在本地解决完冲突之后再提交到云端。

7.在云端实现合并

  • 9
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值