0%

Git

Git常用操作

git rebase

假设一个项目有两个分支,一个是master,一个是dev,你在dev分支上正在开发一个新功能,但是这时候,有人已经在master分支上又有了新的提交,于是你的dev就落后了master一个commit,当你想把dev代码合到master时,需要这样做:

1
2
git pull origin master --rebase
git push --force

git config

git可以进行一些配置,让git在使用的时候更顺手

1
2
3
4
5
6
//加了<--global>代表全局都这样配置,不加代表只在本文件夹内这样配置
git config <--global> user.name "your name"
git config <--global> user.email "your@email.com"

//记住用户名和密码,执行完了这条命令后,git push推送时输入一次账号密码就可以记住了
git config <--global> credential.helper store

git reset

本地commit后发现提交进去了垃圾文件,或者commit的信息写错了,解决如下:
1、git reset –mixed HEAD^
使用 git reset HEAD^ 命令默认的就是mixed模式,此命令表示不删除本地工作空间提交的代码,也即保留对工作区的修改,但是修改未进入暂存区。

2、git reset –soft HEAD^
此命令也表示不删除本地工作空间提交的代码,也即保留对工作区的修改,并且修改已进入暂存区。

3、git reset –hard HEAD^
此命令表示删除本地工作空间提交的代码,也即不保留对工作区的修改,工作区完全回退到上个版本的样子。此命令注意慎用。

三者最大区别
前面两个命令会保留自己在本地的修改(纯撤回提交,如果是提交之后发现有的地方修改错误,可使用这两个命令撤回提交,然后只对错误的地方重新修改,最后再重新提交),而最后一个命令会恢复自己在本地的修改到上一个提交版本。

必备技能
1)HEAD^的意思是上一个版本,也可以写成HEAD~1,如果你进行了2次commit,都想撤回的话,可以使用HEAD~2,以此类推。
2)如果是commit注释写错了,只是想改一下注释,只需要执行命令行:git commit –amend。此时会进入默认Vim编辑器,修改完之后保存即可。
3)浪子回头再回头。意思是我撤回commit后,我又后悔了,我不想撤回了…。此时我们可以通过版本号来回退,先使用 git reflog 命令来获取版本号,再使用 git reset –hard 版本号 命令来恢复。

删除远程仓库的一次commit

这个提交方式,不会在远程仓库留下修改记录,但是谨记一点:强推也会删掉别人的commit记录,所以手速要快

1
2
3
4
5
6
7
8
9
10
commit3  //已经推到远程的一次错误提交
commit2
commit1

如果想回到某次提交,可以这样做:

git reset --hard commitID2
git push -f

但是如果别人有了一次commit4的提交,也会被擦除记录,所以,谨慎使用!请确认别人在commit2后没有提交

远程分支重命名

首先,远程分支是不支持直接重命名的,所以要曲线修改分支名字

1
2
3
git branch -m oldName newName       //1.本地分支:修改打算更改的分支名
git push --delete origin oldName //2.远程分支:删除远程的旧分支
git push -u origin newName //3.本地->远程:推到远程的新建分支上

新建远程分支

1
2
git checkout -b newBranchName       //以当前分支的内容作为基准内容,新建一个分支,并切换过去
git push //将本地的分支推到远程

删除本地分支

git branch --delete oldBranch

变基

  • 原本的远程main分支有若干提交记录:commit id:A->B->C.
  • 拉取到本地新建dev分支,开发新功能,提交新commit:A->B->C->1->2.
  • 此时远程main分支提交了新的commit:A->B->C->D.
  • 将本地main分支更新到D的进度,再切换到dev分支:git rebase main
  • 再切回main分支:git merge dev
  • 此时本地main分支commit顺序为:A->B->C->D->1->2.