git命令学习记录

news/2025/3/4 18:01:27/

git_reset__0">1. git reset 参数说明

git reset 是用来回退版本的,它可以添加三个参数,常用的使用格式是这样的:git reset [--hard | --soft | --mixed] 版本号
一般使用git修改文件并提交需要三步,第一步在文本编辑器中编辑文件,也就是在工作区修改文件;第二步使用git add添加文件,将修改的文件存到暂存区;第三步使用git commit提交文件,将暂存区的文件提交到当前分支。
git reset 的这三个参数对应的就是回退到目标版本后的上面的三种状态:

  • git reset --mixed 版本号回退后是刚使用文本编辑器修改好还没有git add的状态;
  • git reset --soft 版本号回退后是使用使用git add但是还没有使用git commit的状态;
  • git reset --hard 版本号回退后直接就是已经使用git commit提交后的状态;

2. 撤销文件修改

2.1 撤销工作区的文件修改

可以使用以下命令来撤销工作区的文件修改

git checkout -- <filename>git restore <filename>

使用git checkout撤销文件修改的时候不能丢掉后面的--,否则就会变成切换分支的命令,--的前后都应该有空格。
git checkout撤销的是工作区的文件修改,如果撤销修改的文件还没有存到暂存区,那就会回到和版本库一样的状态,如果撤销修改的文件已经存到了暂存区,那就会回到和暂存区一样的状态。
git checkout只会影响工作区,会让文件回到上一次git commit或者git add的状态。
git restore使用时候直接在后面加文件名就可以撤销工作区的修改了。

2.2 撤销暂存区的修改

撤销暂存区的修改也是两条命令

git restore --staged <filename>git reset <filename>

这两个命令只会撤销暂存区的文件修改,如果文件保存到暂存区以后又在工作区进行了修改,这时候使用这两条命令只会影响暂存区的文件,不会影响工作区的内容,如果想同时修改暂存区的工作区就需要和上面的命令结合使用。
如果是文件删除操作已经git add到了暂存区,那么只能使用git restore --staged filename来恢复,这时候git reset是不能用的。

3. 分支管理

3.1 查看当前分支

使用git branch显示当前存在的分支列表。

3.2 创建分支

git branch <dev>git checkout -b <dev>git switch -c <dev>

第一条表示创建分支dev,但是当前的工作分支还是原来的;后面两条表示创建分支dev并将当前的工作分支切换到dev

3.3 切换分支

git checkout <dev>git switch <dev>

这两条命令表示将当前的工作分支切换到dev分支。

3.4 合并分支

git merge <dev>

git merge命令用于合并dev分支到当前分支。
git log --graph --pretty=oneline --abbrev-commit可以查看分支合并图。

3.5 删除分支

git branch -d dev

安全删除本地分支,只有dev分支合已合并的情况下才能使用这个命令删除,把d改成D就可以在未合并的情况下删除本地分支。


http://www.ppmy.cn/news/1576604.html

相关文章

爬虫:一文掌握 Celery 分布式爬虫,及对应实战案例

更多内容请见: 爬虫和逆向教程-专栏介绍和目录 文章目录 1. Celery 简介1.1 什么是 Celery?1.2 Celery 的核心组件2. 环境准备2.1 安装依赖2.2 启动 Redis3. 创建 Celery 分布式爬虫3.1 项目结构3.2 编写 Celery 任务3.3 启动 Worker3.4 分发任务4. 分布式部署4.1 多台机器部…

Java 入门 (超级详细)

一、什么是Java Java是一种高级编程语言&#xff0c;由Sun Microsystems公司于1995年推出。Java具有跨平台性、面向对象、健壮性、安全性、可移植性等特点&#xff0c;被广泛应用于企业级应用开发、移动应用开发、大数据处理、云计算等领域。Java程序可以在不同的操作系统上运…

基于FPGA的一些常识问题

1.FPGA&#xff08;现场可编程门阵列&#xff09;主要由以下几个部分构成‌&#xff1a; ‌1、可编程逻辑单元&#xff08;CLB&#xff09;‌&#xff1a;CLB是FPGA的基本逻辑单元&#xff0c;负责执行大部分的逻辑运算。每个CLB包含一个可配置开关矩阵&#xff0c;该矩阵由多…

【目标检测】目标检测中的数据增强终极指南:从原理到实战,用Python解锁模型性能提升密码(附YOLOv5实战代码)

&#x1f9d1; 博主简介&#xff1a;曾任某智慧城市类企业算法总监&#xff0c;目前在美国市场的物流公司从事高级算法工程师一职&#xff0c;深耕人工智能领域&#xff0c;精通python数据挖掘、可视化、机器学习等&#xff0c;发表过AI相关的专利并多次在AI类比赛中获奖。CSDN…

【Linux vi文本编辑器使用指南】

Linux vi文本编辑器使用指南 一、模式切换二、启动与退出三、光标移动&#xff08;命令模式&#xff09;四、编辑文本五、查找与替换六、其他实用命令七、示例流程八、学习建议 Linux系统中的 vi&#xff08;及其增强版 vim&#xff09;是一款功能强大的文本编辑器&#xff0…

嵌入式产品级-超小尺寸游戏机(从0到1 硬件-软件-外壳)

Ultra-small size gaming console。 超小尺寸游戏机-Pico This embedded product is mainly based on miniaturization, followed by his game functions are also very complete, for all kinds of games can be played, and there will be relevant illustrations in the fo…

距离度量优化与缓存技术——距离度量优化与缓存技术

假设你在处理一个拥有50万条文本数据的分类任务&#xff0c;使用KNN算法时&#xff0c;每次预测需要遍历所有样本计算余弦相似度——单次预测耗时超过20秒&#xff0c;用户等待时间足以让实时推荐系统崩溃。 核心矛盾&#xff1a;距离计算是KNN的核心操作&#xff0c;但也是性…

蓝桥杯 - 每日打卡(类斐波那契循环数)

题目: 解题思路&#xff1a; 假设输入数值为number 分析题目&#xff0c;如果想要解决这个问题&#xff0c;我们需要实现两个方法&#xff0c;第一个检查number是否是类斐波那契&#xff0c;第二个是模拟1e7 - 0的过程&#xff0c;因为是求最大的&#xff0c;那么我们从1e7开始…