git常用命令(patch补丁和解决冲突)

diff/apply方案

使用diff命令生成patch文件,后使用apply命令应用patch到分支,从而实现修改复刻。

生成补丁

复制代码
git diff > commit.patch

检查补丁

复制代码
git apply --check commit.patch

应用补丁

复制代码
git apply commit.patchgit diff --cached > commit.patch

生成最近1次commit的patch

复制代码
git format-patch HEAD^

生成最近2次commit的patch

复制代码
git format-patch HEAD^^

生成单个提交的patch

复制代码
git loggit format-patch [commit-id] -1git format-patch 51d4aa97aaffd754eb7412ff87a3c9ba1fa30006 -1

撤销最近一次本地提交

复制代码
git reset HEAD~

git reset --soft "3fed8d862292d7c0415c97a960b1aca39b138ed3"

git reflog //显示可引用的历史版本记录,找到要撤回的commit的前面的git reset --hard commit_id //恢复到这次修改git push origin HEAD --force //将本地分支代码强制推送到远处分支

撤销最近一次提交但保留更改

复制代码
git reset --soft HEAD~1

撤销最近一次提交并丢弃更改

复制代码
git reset --hard HEAD~1

撤销特定的提交

复制代码
git revert <commit-hash>

修改最近一次提交

复制代码
git commit --amend

撤销已经推送到远程仓库的提交(使用git revert或谨慎使用git push --force)

想彻底删除 Git 中的某次提交的内容,可以使用git rebase命令并将该提交删除

也不会在git log中保留,可以撤销中间某次提交,撤销提交

复制代码
git loggit rebase -i commit_id //进入vim编辑模式,把要删除的commit的前面的pick改为drop git push origin HEAD --force //推到远程分支上

回退版本,并强制提交

复制代码
git log​git reset --hard 25843279fa4c619d2513f181117bc5394b10509fgit push origin dev --force​git reset --hard 0e35fdffc3ce33b1979ed3c8f55554933fbbe991git push origin master --force
相关推荐
二进制coder4 小时前
Git Fork 开发全流程教程
大数据·git·elasticsearch
程序员馨馨4 小时前
不扰远程仓库,本地双版本:master 留 A 稿,分支藏 B 稿
git
无限进步_5 小时前
C语言动态内存的二维抽象:用malloc实现灵活的多维数组
c语言·开发语言·数据结构·git·算法·github·visual studio
用户47861297206925 小时前
Git:如何排查非线性历史中被隐秘覆盖的修改(完整实战笔记)
git
weixin_377634849 小时前
【Git使用】PyCharm中的Git使用
ide·git·pycharm
爱吃泡芙的小白白11 小时前
vscode、anaconda、git、python配置安装(自用)
ide·git·vscode·python·anaconda·学习记录
ALex_zry17 小时前
Git大型仓库推送失败问题解决方案:大文件传输优化指南
git
草莓熊Lotso17 小时前
Git 分支管理:从基础操作到协作流程(本地篇)
大数据·服务器·开发语言·c++·人工智能·git·sql
w***Q35020 小时前
Git工作流自动化
运维·git·自动化
舒一笑1 天前
GitPulse:让代码的故事自己讲述
git·程序员·intellij idea