Git的常用命令及常见问题处理方法
目录
- 一、介绍
- 二、常用 Git 命令
- 1. 配置用户信息
- 2. 初始化仓库
- 3. 克隆远程仓库
- 4. 查看状态
- 5. 添加文件到暂存区
- 6. 提交更改
- 7. 查看提交历史
- 8. 查看文件差异
- 9. 查看分支
- 10. 切换分支
- 11. 合并分支
- 12. 处理冲突
- 13. 远程操作
- 14. 标签管理
- 15. 撤销操作
- 三、常见问题处理方法
- 1. 无法推送到远程仓库
- 2. 分支丢失
- 3. 文件被错误地添加到暂存区
- 4. 回到之前的提交
- 5. 忘记暂存文件
- 6. 提交信息错误
- 7. 删除远程分支
- 8. 文件冲突解决后无法提交
一、介绍
Git 是一个分布式版本控制系统,以下是一些常用的 Git 命令及其使用方法:
二、常用 Git 命令
1. 配置用户信息
git config --global user.name "Your Name" # 配置全局用户名
git config --global user.email "your@email.com" # 配置全局邮箱
2. 初始化仓库
git init # 初始化一个空的 Git 仓库
3. 克隆远程仓库
git clone <repository-url> # 克隆远程仓库到本地
4. 查看状态
git status # 查看当前工作目录的状态
5. 添加文件到暂存区
git add <file> # 添加指定文件到暂存区
git add . # 添加所有文件到暂存区
6. 提交更改
git commit -m "Commit message" # 提交暂存区的更改,并添加提交信息
git commit -am "Commit message" # 一次性提交所有已跟踪文件的更改
7. 查看提交历史
git log # 查看提交历史
git log --oneline # 简要查看提交历史
git log --author="Your Name" # 查看特定用户的提交历史
8. 查看文件差异
git diff # 查看工作目录与暂存区之间的差异
git diff --staged # 查看暂存区与上一次提交之间的差异
git diff <commit1> <commit2> # 比较两个提交之间的差异
9. 查看分支
git branch # 列出所有本地分支
git branch -a # 列出所有本地和远程分支
git branch <branch-name> # 创建新分支
git branch -d <branch-name> # 删除本地分支
git branch -D <branch-name> # 强制删除本地分支
10. 切换分支
git checkout <branch-name> # 切换到指定分支
git checkout -b <branch-name> # 创建并切换到新分支
git checkout -- <file> # 恢复文件到最近一次提交的状态
11. 合并分支
git merge <branch-name> # 合并指定分支到当前分支
12. 处理冲突
在合并或重新合并过程中,若出现冲突,Git 会在冲突文件中用以下标记来显示冲突:
<<<<<<< HEAD
... 冲突内容 ...
=======
... 冲突内容 ...
>>>>>>> branch-name
解决冲突后,使用以下命令提交更改:
git add <file>
git commit -m "Resolved merge conflict"
13. 远程操作
git remote -v # 查看远程仓库地址
git fetch # 获取远程仓库的更新但不合并
git pull # 获取远程更新并合并到当前分支
git push # 将本地提交推送到远程仓库
git push origin <branch-name> # 推送本地分支到远程仓库
14. 标签管理
git tag # 列出所有标签
git tag <tag-name> # 创建新标签
git tag -a <tag-name> -m "Tag message" # 创建带注释的标签
git push origin <tag-name> # 推送标签到远程仓库
15. 撤销操作
git reset --hard HEAD # 撤销工作目录和暂存区的所有更改
git reset HEAD <file> # 将文件从暂存区移除但保留工作目录的更改
git revert <commit> # 创建一个新的提交来撤销指定提交的更改
三、常见问题处理方法
1. 无法推送到远程仓库
#可能是因为远程分支的HEAD指向了非引用,或者远程仓库拒绝更新
git push --set-upstream origin <branch-name> # 设置上游分支
git pull origin <branch-name> # 拉取远程更新
git push origin <branch-name> # 再次尝试推送
2. 分支丢失
可能是因为分支被删除或覆盖
git reflog # 查看 Git 引用日志
git checkout <commit-hash> # 切换到指定的提交
git branch <branch-name> # 创建新分支
3. 文件被错误地添加到暂存区
git reset HEAD <file> # 取消暂存单个文件
git reset HEAD # 取消暂存所有文件
4. 回到之前的提交
git checkout <commit-hash> # 切换到指定的提交
git checkout -b <branch-name> # 创建新分支
git reset --hard <commit-hash> # 强制重置当前分支到指定提交
5. 忘记暂存文件
git add <file> # 添加文件到暂存区
git commit --amend # 修改最后一次提交
6. 提交信息错误
git commit --amend -m "Corrected commit message" # 修改最后一次提交的信息
7. 删除远程分支
git push origin --delete <branch-name> # 删除远程分支
8. 文件冲突解决后无法提交
git add <file> # 添加解决冲突后的文件
git commit -m "Resolved conflict" # 提交更改
相关文章:
Git的常用命令及常见问题处理方法
目录 一、介绍二、常用 Git 命令1. 配置用户信息2. 初始化仓库3. 克隆远程仓库4. 查看状态5. 添加文件到暂存区6. 提交更改7. 查看提交历史8. 查看文件差异9. 查看分支10. 切换分支11. 合并分支12. 处理冲突13. 远程操作14. 标签管理15. 撤销操作 三、常见问题处理方法1. 无法推…...
基于vue3实现的课堂点名程序
设计思路 采用vue3实现的课堂点名程序,模拟课堂座位布局,点击开始点名按钮后,一朵鲜花在座位间传递,直到点击结束点名按钮,鲜花停留的座位被点名。 课堂点名 座位组件 seat.vue <script setup>//组合式APIimpo…...
kkFileView二开之pdf转图片接口
kkFileView二开之Pdf转图片接口 kkFileView二开系列文章:1 kkFileView源码下载及编译2 Pdf转图片接口2.1 背景2.2 分析2.2 接口开发2.2.1 编写Pdf转图片方法2.2.2 编写转换接口 2.3 接口测试2.3.1 Pdf文件准备2.3.2 pdf2Image 3 部署 kkFileView二开系列文章&#x…...
神经网络常见激活函数 9-CELU函数
文章目录 CELU函数导函数函数和导函数图像优缺点pytorch中的CELU函数tensorflow 中的CELU函数 CELU 连续可微指数线性单元:CELU(Continuously Differentiable Exponential Linear Unit),是一种连续可导的激活函数,结合了 ELU 和 …...
什么是网关?网关有什么作用?API网关的主要功能,SpringCloud可以选择有哪些API网关?什么是限流算法?网关如何实现限流?一篇文章读懂网关的前世今生
1、什么是网关? API网关(API Gateway)是一种中间层服务器,用于集中管理,保护和路由对后端服务的访问。它充当了客户端与后端服务之间的入口点,提供了一组统一的接口管理和控制API的访问。 2、网关示意图 3…...
OpenCV机器学习(1)人工神经网络 - 多层感知器类cv::ml::ANN_MLP
操作系统:ubuntu22.04 OpenCV版本:OpenCV4.9 IDE:Visual Studio Code 编程语言:C11 算法描述 cv::ml::ANN_MLP 是 OpenCV 库中的一部分,用于实现人工神经网络 - 多层感知器(Artificial Neural Network - Multi-Layer…...
DeepSeek告别服务器繁忙
原文地址:http://shen.iwiki.fun/2025/02/09/free-deepseek/ 博客地址:http://shen.iwiki.fun 一、申请API 1、硅基流动 免费额度:14元 注:平台 2000 万 Tokens 特指 Qwen2.5-14B-Instruct 模型单价下的数量,实际到账…...
线性代数中的正交和标准正交向量
在线性代数中,理解正交向量和正交向量至关重要,尤其是对于机器学习中的应用。这篇博文将简化这些概念,而不会太深入地深入研究复杂的数学。 正交向量 如果两个向量的点积等于零,则认为这两个向量是正交的。但点积到底是什么呢&am…...
从安装软件到flask框架搭建可视化大屏(一)——创建一个flask页面,零基础也可以学会
1.第一步:安装软件 Flask是一个轻量级Web应用框架,用python代码编写,简单方便应用。 如何安装pycharm_pycharm只能安装在c盘吗-CSDN博客 Pycharm分为专业版和社区版,是python的主流工具 如何安装Anaconda_如何安装anacoda csdn-…...
python opencv基础使用总结
1.安装opencv库:pip install opencv-python 2.基础使用范例 import cv2 #图片的基本操作#1.读取一张图片 参数 1:图片的文件名如果图片放在当前文件夹下,直接写文件名就行,如lena.jpg否则需要给出绝对路径,如D:\Ope…...
【已解决】TypeError: AsyncConnectionPool.__init__(), new install bug, httpx==0.24.1
1,参考社区链接,首先降低gradio版本,降低到4以下,但是也不能降太低,也不能太高,要适中,推荐版本3.39.0 pip install gradio3.39.0 2,下载正确的httpx版本 参考社区链接࿰…...
react中如何获取真实的dom
在 React 中,获取真实的 DOM 元素通常通过 ref 来实现。ref 是一个特殊的属性,用于引用组件或 DOM 元素的实例。你可以通过 ref 获取到组件的真实 DOM 元素或组件实例。 1. 函数组件中的 useRef 在函数组件中,获取 DOM 元素的引用需要使用 …...
HTTP协议 (爬虫)
本质上 协议就是两个计算机协商好相互沟通的方式 计算机传输的数据是0or1 需要协商好数据的规则。HTTP协议是传输网站相关的东西的。 HTTP把一条消息分成三个部分 请求: 请求行:请求方式(get、post) 请求URL 协议 请求头&a…...
Python elasticsearch客户端连接常见问题整理
python 访问 elasticsearch 在python语言中,我们一般使用 pip install elasticsearch 软件包,来访问es服务器。 正确用法 本地安装elasticsearch时,应指定与服务端相同的大版本号: pip install elasticsearch7.17.0然后就可以…...
清华大学KVCache.AI团队联合趋境科技联合的KTransformers开源项目为什么那么厉害
KTransformers是一个由清华大学KVAV.AI团队开发的开源项目,旨在优化大语言模型(LLM)的推理性能,特别是在有限显存资源下运行大型模型。以下是KTransformers的详细介绍: 1. 核心特点 高性能优化:KTransfor…...
matlab模拟风场的随机脉动风
1、内容简介 matlab137-模拟风场的随机脉动风 可以交流、咨询、答疑 2、内容说明 略 模拟风场的随机脉动风,并进行相关的统计分析和计算,包括风速谱、空间相关性、自谱、互谱、以及POD(Proper Orthogonal Decomposition)分解等…...
Code::Blocks 创建 C 项目 二
Code::Blocks 创建 C 项目 二 Code::Blocks 安装请看 Code::Blocks 安装 启动 Code Blocks 选择 Create a new project 弹出界面选择 Projects -> Console application -> Go 选择 C :表示创建的是 C 语言项目 点击 Next Project title:项目名 …...
Javascript网页设计案例:通过PDF.js实现一款PDF阅读器,包括预览、页面旋转、页面切换、放大缩小、黑夜模式等功能
前言 目前功能包括: 切换到首页。切换到尾页。上一页。下一页。添加标签。标签管理页面旋转页面随意拖动双击后还原位置 其实按照自己的预期来说,有很多功能还没有开发完,配色也没有全都搞完,先发出来吧,后期有需要…...
【IoTDB 线上小课 11】为什么 DeepSeek 要选择开源?
新年新气象,【IoTDB 视频小课】第十一期全新来临! 关于 IoTDB,关于物联网,关于时序数据库,关于开源... 一个问题重点,3-5 分钟,我们讲给你听: 开源“加成”再次展现! 现在…...
【ESP32】ESP-IDF开发 | WiFi开发 | HTTPS服务器 + 搭建例程
1. 简介 1.1 HTTPS HTTPS(HyperText Transfer Protocol over Secure Socket Layer),全称安全套接字层超文本传输协议,一般理解为HTTPSSL/TLS,通过SSL证书来验证服务器的身份,并为浏览器和服务器之间的通信…...
ollama离线环境部署deepseek及对话网站开发
ollama离线环境部署deepseek及局域网对话网站开发 需要在离线环境下面部署deepseek大模型,而且局域网内用户能在浏览器直接对话,主机的操作系统是win10 经不断探索,找到一条能走通的路,大致流程和思路如下: 局域网服…...
【Unity】 HTFramework框架(六十)Assistant助手(在Unity中接入DeepSeek等AI语言大模型)
更新日期:2025年2月14日。 Github源码:[点我获取源码] Gitee源码:[点我获取源码] 索引 Assistant助手安装Ollama使用Assistant(在编辑器中)打开Assistant配置Assistant使用Assistant处理Assistant回复的内容使用推理大…...
Spring AI集成DeepSeek,实现流式输出
前面一篇文章我们实现了《Spring AI集成DeepSeek:三步搞定Java智能应用》,大模型的响应速度是很慢的,为了提升用户体验,我们通常会使用流式输出一点点将结果输出给用户。先看下效果: 在 SpringBoot 中实现流式输出可以…...
LeetCode 1299.将每个元素替换为右侧最大元素:倒序遍历,维护最大值,原地修改
【LetMeFly】1299.将每个元素替换为右侧最大元素:倒序遍历,维护最大值,原地修改 力扣题目链接:https://leetcode.cn/problems/replace-elements-with-greatest-element-on-right-side/ 给你一个数组 arr ,请你将每个…...
搭建一个经典的LeNet5神经网络
第一章:计算机视觉中图像的基础认知 第二章:计算机视觉:卷积神经网络(CNN)基本概念(一) 第三章:计算机视觉:卷积神经网络(CNN)基本概念(二) 第四章:搭建一个经典的LeNet5神经网络 一、LeNet-5背景 LeNet-…...
我用Ai学Android Jetpack Compose之CircularProgressIndicator
答案来自 通义千问 Q: 我想学习CircularProgressIndicator,麻烦你介绍一下 当然可以!CircularProgressIndicator 是 Jetpack Compose 中的一个组件,用于显示一个循环的圆形进度条。它非常适用于需要指示加载状态或进程完成度的场景。接下来…...
DeepSeek-R1:通过强化学习激励大型语言模型的推理能力
摘要 我们介绍了第一代推理模型DeepSeek-R1-Zero和DeepSeek-R1。DeepSeek-R1-Zero是一个通过大规模强化学习(RL)训练而成的模型,无需监督微调(SFT)作为初步步骤,展示了卓越的推理能力。通过RL,DeepSeek-R1-Zero自然涌现出许多强大而有趣的推理行为。然而,它也面临诸如…...
为什么要选择3D机器视觉检测
选择3D机器视觉检测的原因主要包括以下几点: 高精度测量 复杂几何形状:能够精确测量复杂的三维几何形状。 微小细节:可捕捉微小细节,适用于高精度要求的行业。全面数据获取 深度信息:提供深度信息,弥补2D视…...
Unity 编辑器热更C# FastScriptReload
工具源码:https://github.com/handzlikchris/FastScriptReload 介绍 用于运行时修改C#后能快速重新编译C#并生效,避免每次改C#,unity全部代码重新编译,耗时旧且需要重启游戏。 使用 需要手动调整AssetPipeline自动刷新模式&…...
DeepSeek在linux下的安装部署与应用测试
结合上一篇文章,本篇文章主要讲述在Redhat linux环境下如何部署和使用DeepSeek大模型,主要包括ollama的安装配置、大模型的加载和应用测试。关于Open WebUI在docker的安装部署,Open WebUI官网也提供了完整的docker部署说明,大家可…...
