git命令学习

git 主要通过操作工作区、暂存区、版本库来实现代码管理。

  • 工作区:就是你在电脑里能看到的目录。
  • 暂存区:英文叫stage, 或index。一般存放在 ".git目录下" 下的index文件(.git/index)中,所以我们把暂存区有时也叫作索引(index)。
  • 版本库:工作区有一个隐藏目录.git,这个不算工作区,而是Git的版本库。

下面这个图展示了工作区、版本库中的暂存区和版本库之间的关系:

注:以上来自git菜鸟教程。、

1、git reset 

(1) git reset 重置HEAD

git reset --soft HEAD~     :将当前HEAD指向的分支回退到上次提交后的状态,并不改变暂存区以及工作目录的内容,撤销当前git commit经常使用这个命令;

git reset --mixed HEAD~   或者  git reset HEAD~ (git reset 命令默认参数为 --mixed):将当前HEAD指向的分支回退到上次提交后的状态,取消暂存区的内容,但不改变工作目录的内容,与git add 功能刚好相反;

git reset --hard HEAD~     :将当前HEAD指向的分支回退到上次提交后的状态,取消暂存区的内容,同时工作目录的内容也会被重新覆盖;

注:HEAD其实就是一个指向当前分支的指针,HEAD~就是指当前分支上次提交版本

(2) git reset 重置目录或文件

git reset 【--mixed】【HEAD】 filename  (【--mixed】和【HEAD】可以省略): 将filename 文件取消暂存;

git reset --hard 【HEAD】filename  (【HEAD】可以省略): 将filename 文件取消暂存,并撤销工作目录中该文件的修改,与这条命令与  git checkout --  filename  功能类似;

2、git checkout

(1) git checkout 【branch】

切换当前HEAD指向的分支,切换分支必须先确保本地没有未提交的暂存或者修改。

(2) git checkout -b【branch】【remotename】 /【branch1】

新建分支branch,并切换当前HEAD指向的分支branch,执行这条命令必须先确保本地没有未提交的暂存或者修改。

如果后面有【remotename】 /【branch】  那么新建的分支就会自动最终远程服务器上branch1分支

(3) git checkout --track  【remotename】 /【branch】

设置本地当前分支自动追踪远程服务器branch分支;

(4) git checkout -- 【file】

 将filename 文件取消暂存,并撤销工作目录中该文件的修改,与这条命令与  git reset --hard filenam 功能类似;

 

3、git merge 

上图有两个分支origin 和 mywork,现在将两个分支合并

执行  git checkout mywork 

         git merge origin 

git checkout 会切换分支到mywork,git merge 会找到  当前分支与origin 两个分支共同祖先,图中C2这个节点,以C2为基础,将mywork与origin合并生成下图的C7节点。这种叫做git merge 三方合并。

4、git rebase 变基

执行  git checkout mywork 

         git rebase origin 

git checkout 会切换分支到mywork,git rebase 会将origin分支上的更改在mywork分支上重现,形成下图所示的C5'和C6'。

下面就可以执行git merge操作

git checkout origin

git merge mywork

上面命令先切换到origin分支,再将mywork分支合入origin,那么上图中origin和mywork会同时指向C6',这种也叫作git merge  单线合入。

在执行 git branch -d mywork 可以删除mywork分支;

5、git stash 储藏

储藏用于当代码写了一半,然而又不想将一半工作提交,这时候可以使用git stash将当前工作暂时储存起来。

git stash :将当前分支里做的工作储藏

git stash list :查看当前储藏的记录

git stash apply 【储藏记录中的某个】【--index】

应用储藏记录中的某一个,默认为最近储藏的记录,--index指将储藏时候暂存区的内容再次暂存;

git stash branch 【branch】: 恢复储藏区的内容到新分支branch上;

 

 

 

 

 

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值