GIT常用操作
创始人
2024-05-04 06:09:00
0

GIT 日常使用总结

    • git stash
    • git merge
    • git rebase
    • 将多个commit合并成一个commit
    • git revert
    • 撤销修改
    • 撤销commit 但是不撤销add 的内容
    • 撤销add
    • GIT Rebase 补充说明:


git stash

  • git stash:将修改后的代码存储到本地的一个栈结构,将工作区和暂存区恢复到修改之前,一般在git pull拉取代码失败时使用,可以跨分支使用
  • git stash pop:将stash的代码恢复,该命令会自动将pop的代码与本地代码进行merge
    具体用法:
  • git stash save ‘message’ message为本次保存的说明信息
  • git stash pop stash@{num} 弹出stash的内容,默认弹出最近一次stash的内容,即stash@{0}
  • git stash list列出所有保存的记录列表,数字越小表示保存时间越近
  • git stash apply stash@{num}弹出stash的内容,默认弹出最近一次stash的内容,可重复弹出
  • git stash drop stash@{num}删除某一条stash的内容
  • git stash clear删除所有stash内容
  • 注:git stash pop或者drop后,stash的序号会自动改变

使用场景:当git pull远程分支的代码时,与本地代码有冲突导致失败
操作:

  1. git stash 将修改后的代码存储到本地
  2. git pull拉取远程仓库代码
  3. git stash pop将pop的代码与pull后的代码进行merge
  4. 解决完冲突之后再进行add、commit即可

git merge

  1. git merge用于将指定的commits合并到当前分支
  2. git merge --abort通常在merge合并后有冲突时使用,表示放弃本次合并
    使用场景: 当远程master分支发生了变化,想要将远程master分支上的变化更新到本地开发分支(dev)上的代码
    操作
  3. git checkout master从dev分支切换到master分支
  4. git pull 拉取远程仓库master分支代码至本地master分支
  5. git checkout dev
  6. git merge master合并master分支至dev分支,此时处于dev分支
  • 当在dev分支上开发完成后,需要合并到master分支

将master 分支合并到当前分支:将基准(master)分支合并到当前分支,等同于:git checkout replier-server-api_1-0-54_BRANCH && git merge master

将当前分支合并到基准(master)分支,等同于:git checkout master && git merge replier-server-api_1-0-51_BRANCH
*

git rebase

使用场景
在本地创建一个dev分支进行开发,开发完成后可以提交代码至远程master分支,但是此时远程master已经有了新的提交
操作

  1. git checkout master 切换到本地master分支
  2. git pull 拉取远程master分支最新代码至本地master
  3. git checkout dev
  4. git rebase -i HEAD~n表示将dev分支上的n次commit合并成一个
  5. git rebase master将master分支代码同步到本地,此处需要解决冲突
  6. 解决完冲突之后,执行git add.,再git rebase --continue
  7. git checkout master
  8. git merge dev将本地dev分支内容合并到master分支

将多个commit合并成一个commit

使用场景:
使用git log查看commit提交历史时,想将最近的两个提交85608和0109a合并成一个commit

在这里插入图片描述
操作:

  1. git rebase -i commitId commitId是不需要合并的commit的hash值(例如倒数第三个)
  • 注意:在执行此命令时,需要确保工作区是干净的,否则就会报如下错误
  • -i 后面的参数是待合并的两个commit 之前的一个commit 的hash 值,和待合并的两个commit 没有关系
  • 确保工作区是干净的可以使用git stash 进行暂存,执行万rebase 之后使用git stash pop 恢复暂存的内容
    在这里插入图片描述
  1. 输入此命令后就会展示以下界面
  • pick 的意思是要会执行这个 commit
  • squash 的意思是这个 commit 会被合并到前一个commit
    输入i进入编辑模式,将a9e3前面的pick改成s或者squash,然后输入:wq保存并退出
  1. 注意:squash 选择最近一次的提交的HASH 值,需要确保这个Hash 前面是有commit 的,比如这里最近一次的提交是85608,则将85608 前面的pick 修改为squash即可

在这里插入图片描述

  1. 然后进入commit的编辑页面,需要输入合并后的commit的提交信息,操作方式类似于步骤二,至此就完成了commit的合并。commit 的信息可在第一行添加

git revert

  • git revert 撤销某次的提交,此操作不会修改原有的提交记录,而是会新增一条提交记录来抵消某次某次操作
  • git revert 针对普通的commit
  • git revert -m 针对merge的commit
  • git revert 回滚多次的提交,这是一个前开后闭区间,即不包括commit1,但是包括commit2
    使用场景
    在提交了一次携带bug的commit之后,又进行了两次提交,此时想撤销携带bug的那次提交,但是又想保留之后的两次提交,记录下整个的提交记录,就可以使用该指令
    在这里插入图片描述

例如想撤销 0109a6 那次的提交,同时保留之后的那次 856082 的那次提交,就可以使用git revert 0109a672 ,就会新增一条commit 记录


撤销修改

  • git log:查看提交历史
  • git reflog:查看命令历史,包括撤销修改的命令
  • git checkout – :当文件已经修改但还未存入暂存区(还未add),此命令可撤销工作区的修改
  • git reset HEAD :当文件已经做了修改并且存入暂存区,此命令可以撤销暂存区的修改,将改动放回到工作区
  • git reset --hard :修改的文件已经commit,使用该命令可以撤销commit的修改,将工作区恢复到上一次commit的状态

撤销commit 但是不撤销add 的内容

  • git reset --soft HEAD^
  • https://www.cnblogs.com/lfxiao/p/9378763.html

撤销add

  • git rm ./roi_ltv/script/renew/* --cached

GIT Rebase 补充说明:

  • https://blog.csdn.net/jiangbo721/article/details/95194859

相关内容

热门资讯

【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
AsusVivobook无法开... 首先,我们可以尝试重置BIOS(Basic Input/Output System)来解决这个问题。...
月入8000+的steam搬砖... 大家好,我是阿阳 今天要给大家介绍的是 steam 游戏搬砖项目,目前...
​ToDesk 远程工具安装及... 目录 前言 ToDesk 优势 ToDesk 下载安装 ToDesk 功能展示 文件传输 设备链接 ...