Git的相关使用(工作常用)

一、撤销的相关命令(重要!!!)

1. 使用 git reset

(a)软重置

如果你想撤销最近的提交,但保留文件的更改(即将它们放回暂存区),可以使用:

java 复制代码
git reset --soft HEAD~1
(b)混合重置(默认)

如果你想撤销最近的提交,并将更改放回工作目录(即不再暂存这些更改),可以使用:

java 复制代码
git reset HEAD~1
(c)硬重置

如果你想完全丢弃最近的提交及其更改,可以使用:

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

注意:硬重置会永久删除未提交的更改,请谨慎使用。

2. 使用 git revert

如果你已经将提交推送到远程仓库,并且不想改变历史记录,可以使用 git revert。这个命令会创建一个新的提交,撤销指定的提交:

java 复制代码
git revert HEAD

这会生成一个新的提交,内容是撤销最后一次提交的更改。

3. 查看提交历史

在执行任何操作之前,建议查看提交历史,以确保你要撤销的提交是正确的。你可以使用:

java 复制代码
git log

这个命令会显示提交历史,包括每个提交的哈希值、作者、日期和提交信息。

4. 强制推送(如果需要)

如果你使用 git reset 并且需要将更改推送到远程仓库,你可能需要强制推送:

如果你不知道当前在哪个分支可以查看一下(因为强制推送不可逆,所以确定好强制推送到正确的分支)!!!

4.1、查看当前分支

java 复制代码
git branch

4.2、强制推送

java 复制代码
git push --force

4.3、强制推送到指定的分支

java 复制代码
git push origin <branch-name> --forc

警告:强制推送会覆盖远程分支的历史记录,可能会导致其他开发者的本地仓库出现问题。因此,在团队协作时应谨慎使用。

二、Git的基本命令

初始化仓库

java 复制代码
git init

克隆远程仓库

java 复制代码
git clone <repository-url>

查看当前状态

java 复制代码
git status

添加文件到暂存区

java 复制代码
git add <file-name>

或者添加所有文件:

java 复制代码
git add .

提交更改

java 复制代码
git commit -m "commit message"

查看提交历史

java 复制代码
git log

三、 分支管理

1、查看分支

css 复制代码
git branch

2、创建新分支:

css 复制代码
git branch <branch-name>

3、切换分支

css 复制代码
git checkout <branch-name>

4、创建并切换到新分支:

css 复制代码
git checkout -b <branch-name>

5、合并分支:

css 复制代码
git merge <branch-name>

四、 远程操作

1、查看远程仓库

css 复制代码
git remote -v

2、添加远程仓库

css 复制代码
git remote add <name> <repository-url>

3、推送到远程仓库

css 复制代码
git push <remote> <branch-name>

4、从远程仓库拉取更改

css 复制代码
git pull <remote> <branch-name>

5、获取远程更新

css 复制代码
git fetch

五、其他常用命令

1、查看修改内容

css 复制代码
git diff

2、重置文件到最后一次提交

css 复制代码
git checkout -- <file-name>

3、撤销最近的提交(保留更改):

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

4、删除分支:

css 复制代码
git branch -d <branch-name>
相关推荐
AlexDeng2 小时前
Git 中模糊搜索分支名称并创建本地跟踪分支
git
jxm_csdn6 小时前
递归工程工厂:Claude Code + Git Worktrees + Tilix/Tmux 的“AI分身”编码团队
人工智能·git
码咔吧咔6 小时前
Git 中 pull.rebase = true 的作用与设置方法详解
git
郑州光合科技余经理9 小时前
开发实战:海外版同城o2o生活服务平台核心模块设计
开发语言·git·python·架构·uni-app·生活·智慧城市
我是海飞9 小时前
Git 本地仓库推送到远程空仓库指南
大数据·git·elasticsearch
记得开心一点嘛9 小时前
如何去使用git进行协同开发?
git
GHL28427109019 小时前
git cherry-pick使用
git
小龙21 小时前
【Git 报错解决】本地分支与远程分支名称/提交历史不匹配
大数据·git·elasticsearch·github
阿正的梦工坊21 小时前
Git Rebase 是什么?为什么需要它?
人工智能·git
ASEpochs1 天前
Vsocde中‘sh’不是内部或外部命令,也不是可运行的程序或批量处理文件--已解决
git·vscode·bash