Git命令大全(超详细)

Git 是一个分布式版本控制系统,用于跟踪计算机文件的更改,并协调多个用户之间的工作。下面是一份较为详细的 Git 命令大全,涵盖了从初始化仓库到日常使用中常见的操作。

1. 初始化与配置

  • 设置用户信息:
    • git config --global user.name "Your Name": 设置全局用户名。
    • git config --global user.email "your.email@example.com": 设置全局邮箱。
    • 若要为特定仓库设置不同的信息,可以在仓库目录下运行上述命令而不带 --global 参数。
  • 初始化仓库:
    • git init: 在当前目录创建一个新的 Git 仓库。
    • git clone <repository>: 克隆一个远程仓库到本地指定路径。例如:git clone https://github.com/user/repo.git

2. 工作区、暂存区和提交

  • 添加文件至暂存区:
    • git add .: 添加所有修改过的文件到暂存区。
    • git add <file>: 只添加指定文件。
  • 提交更改:
    • git commit -m "commit message": 提交暂存区的内容,并附上说明。
    • git commit --amend: 修改最近一次提交的信息或内容(可以加入新的文件)。
  • 撤销操作:
    • git reset HEAD <file>: 将文件从暂存区移回工作区,但保留改动。
    • git checkout -- <file>: 放弃对文件的所有未提交修改。
    • git clean -f: 删除未被追踪的文件和目录(谨慎使用 -f 标志)。

3. 分支管理

  • 创建分支:
    • git branch <branch-name>: 创建新分支但不切换过去。
    • git checkout -b <branch-name> 或者 git switch -c <branch-name>: 创建并立即切换到新分支。
  • 切换分支:
    • git checkout <branch-name>git switch <branch-name>.
  • 合并分支:
    • git merge <branch-to-merge>: 将指定分支合并到当前分支。
  • 删除分支:
    • git branch -d <branch-name>: 安全删除已完全合并的分支。
    • git branch -D <branch-name>: 强制删除分支,即使它没有被合并。

4. 查看状态与历史

  • 查看状态:
    • git status: 显示工作目录中哪些文件被修改了,哪些文件在暂存区等。
  • 查看日志:
    • git log: 显示提交记录,默认显示所有分支的提交。
    • git log --oneline --graph --all --decorate: 以简洁格式展示带有图形的历史记录。
  • 差异比较:
    • git diff: 比较工作区与暂存区的差异。
    • git diff --cached: 比较暂存区与最新提交的差异。
    • git diff <commit1> <commit2>: 比较两个提交之间的差异。

5. 远程仓库

  • 添加远程仓库:
    • git remote add origin <url>: 添加名为 origin 的远程仓库。
  • 获取更新:
    • git fetch origin: 获取远程仓库的最新信息,但不自动合并到本地分支。
  • 拉取更新:
    • git pull origin master: 从远程仓库拉取最新的代码并尝试合并到当前分支。
  • 推送更改:
    • git push origin master: 推送本地 master 分支到远程仓库。
    • git push -u origin <new-branch>: 首次推送新分支时使用 -u 参数建立跟踪关系。
  • 查看远程仓库:
    • git remote -v: 列出所有配置的远程仓库及其 URL。
  • 删除远程仓库链接:
    • git remote remove origin: 移除名为 origin 的远程仓库链接。

6. 标签

  • 创建标签:
    • git tag <tagname>: 对最新提交打标签。
    • git tag -a <tagname> -m "msg": 创建带注释的标签。
  • 查看标签:
    • git show <tagname>: 显示指定标签的详细信息。
  • 推送标签:
    • git push origin <tagname>: 推送单个标签到远程仓库。
    • git push origin --tags: 推送所有标签到远程仓库。
  • 删除标签:
    • git tag -d <tagname>: 删除本地标签。
    • git push origin :refs/tags/<tagname>: 删除远程标签。

7. 高级特性

  • 变基:
    • git rebase <branch>: 将当前分支的提交重新应用到另一分支之上。
  • 选择性应用提交:
    • git cherry-pick <commit>: 应用其他分支上的某个特定提交。
  • 二分查找问题:
    • git bisect start: 开始二分查找过程。
    • git bisect bad <commit>: 标记某提交引入了错误。
    • git bisect good <commit>: 标记某提交是好的。
    • git bisect reset: 结束二分查找过程。
  • 恢复丢失的工作:
    • git reflog: 记录了HEAD指针的变化,可用于恢复丢失的提交。
    • git fsck --lost-found: 查找孤立的对象,可能包含丢失的数据。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/62894.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【Vue3】main.js

【Vue3】main.js 创建Vue应用实例引入并配置路由配置状态管理挂载应用全局属性与方法使用其他插件 在Vue 3项目中&#xff0c;main.js 文件是整个应用的入口点。 它负责初始化Vue实例、配置全局选项、注册全局组件、引入插件以及挂载Vue实例到DOM上。 通过 main.js&#xff0c;…

Scratch游戏推荐 | 星际前线:帝国逆袭——揭开帝国野心,挑战星际极限!

今天推荐一款充满科幻与冒险元素的Scratch作品——《星际前线&#xff1a;帝国逆袭》&#xff01;由theChAOTiC制作&#xff0c;这款游戏让你踏入危险的星际前线&#xff0c;与暴虐的Terran帝国展开激烈对抗。在这里&#xff0c;你将探索未知的星域&#xff0c;击败强大的Boss&…

【语音识别】Zipformer

Zipformer 是kaldi 团队于2024研发的序列建模模型。相比较于 Conformer、Squeezeformer、E-Branchformer等主流 ASR 模型&#xff0c;Zipformer 具有效果更好、计算更快、更省内存等优点。并在 LibriSpeech、Aishell-1 和 WenetSpeech 等常用数据集上取得了当时最好的 ASR 结果…

《Vue零基础入门教程》第十五课:样式绑定

往期内容 《Vue零基础入门教程》第六课&#xff1a;基本选项 《Vue零基础入门教程》第八课&#xff1a;模板语法 《Vue零基础入门教程》第九课&#xff1a;插值语法细节 《Vue零基础入门教程》第十课&#xff1a;属性绑定指令 《Vue零基础入门教程》第十一课&#xff1a;事…

Docker的常用的容器隔离机制简介

一、Namespace Linux Namespace是Linux内核提供的一种机制,它用于隔离不同进程的资源视图,使得每个进程都拥有独立的资源空间,从而实现进程之间的隔离和资源管理。通过使用Namespace,可以在一个物理主机上创建多个独立的虚拟环境,每个环境都有自己的进程、文件系统、网络…

buuctf-[SUCTF 2019]EasySQL 1解题记录

把你的旗帜给我&#xff0c;我会告诉你这面旗帜是对的。 堆叠注入查询数据库 1; show databases; ​ 查询表名 1; show tables; 获取flag 1;set sql_modepipes_as_concat;select 1

云原生周刊:Kubernetes 和 Docker 的对比

开源项目推荐 Dokploy Dokploy 是一个功能强大的开源平台&#xff0c;为开发者提供与 Vercel、Netlify 和 Heroku 类似的全栈部署与托管体验。它支持现代化的开发工作流&#xff0c;提供快速、可靠的部署服务&#xff0c;涵盖前端、后端和全栈应用。 Dokploy 的开源特性让开…

整数benders分解算法

整数Benders分解算法是一种用于解决混合整数规划问题的算法&#xff0c;由Jacques F. Benders在1962年首次提出。这种算法特别适用于那些包含连续变量和整数变量的极值问题&#xff0c;即混合整数规划问题&#xff08;MIP&#xff09;。在实际应用中&#xff0c;它不仅局限于MI…

Git的基本使用操作

文章目录 Git 全局配置基本操作Git 常用命令版本回退根据版本号回滚分支远端分支 &#x1f3e1;作者主页&#xff1a;点击&#xff01; &#x1f916;Git专栏&#xff1a;点击&#xff01; ⏰️创作时间&#xff1a;2024年12月1日12点50分 Git 全局配置 虽然说是全局配置&am…

飞凌嵌入式受邀亮相OpenHarmony人才生态大会2024

2024年11月27日&#xff0c;OpenHarmony人才生态大会2024在武汉洲际酒店举行。在这场汇聚了行业精英、技术大咖及生态伙伴的年度盛会上&#xff0c;飞凌嵌入式作为OpenHarmony社区的重要成员受邀出席&#xff0c;并展示了其在OpenHarmony 4.1系统适配方面的最新成果。 在大会的…

45 基于单片机的信号选择与温度变化

目录 一、主要功能 二、硬件资源 三、程序编程 四、实现现象 一、主要功能 基于51单片机&#xff0c;采用DS18B20检测温度&#xff0c;通过三种LED灯代表不同状态。 采用DAC0832显示信号脉冲&#xff0c;通过8位数码管显示温度。 信号脉冲可以根据两个按键分别调整为正弦…

Java int[]与ArrayList<>数组 转换 详解

在 Java 中&#xff0c;int[] 与 ArrayList<Integer> 是两种常用的数据结构。由于 int[] 是基本数据类型数组&#xff0c;而 ArrayList<Integer> 是对象集合类型&#xff0c;两者的转换需要注意类型转换的细节。以下是完整的讲解和实现方法。 1. int[] 转换为 Arra…

大数据新视界 -- Hive 基于 MapReduce 的执行原理(上)(23 / 30)

&#x1f496;&#x1f496;&#x1f496;亲爱的朋友们&#xff0c;热烈欢迎你们来到 青云交的博客&#xff01;能与你们在此邂逅&#xff0c;我满心欢喜&#xff0c;深感无比荣幸。在这个瞬息万变的时代&#xff0c;我们每个人都在苦苦追寻一处能让心灵安然栖息的港湾。而 我的…

Qt 2D绘图之三:绘制文字、路径、图像、复合模式

参考文章链接: Qt 2D绘图之三:绘制文字、路径、图像、复合模式 绘制文字 除了绘制图形以外,还可以使用QPainter::darwText()函数来绘制文字,也可以使用QPainter::setFont()设置文字所使用的字体,使用QPainter::fontInfo()函数可以获取字体的信息,它返回QFontInfo类对象…

React-状态管理详解

1、传统MVC框架的缺陷 什么是MVC&#xff1f; MVC的全名是Model View Controller&#xff0c;是模型(model)&#xff0d;视图(view)&#xff0d;控制器(controller)的缩写&#xff0c;是一种软件设计典范。 V即View视图是指用户看到并与之交互的界面。 M即Model模型是管理数…

AI潮汐日报1128期:Sora泄露引发争议、百度早期研究对AI领域Scaling Law的贡献、Meta发布系列AI开源项目

AI 潮汐日报&#xff0c;旨在提供最新潮、最核心、最有意思的AI速递。四大专栏&#xff1a;今日热点、应用速递、研究进展、思维碰撞。 今日热点 OpenAI文本转视频模型Sora泄露引发争议 OpenAI的文本转视频AI模型Sora在Hugging Face上遭遇泄露&#xff0c;泄露者为参与测试的…

PH热榜 | 2024-12-02

1. Muku.ai 标语&#xff1a;AI网红广告代理公司 介绍&#xff1a;木库AI是家AI网红营销机构&#xff0c;利用AI虚拟形象创作用户原创视频广告。只需提供产品链接&#xff0c;就能生成吸引人的内容&#xff0c;从而提升各大平台的销售额。 产品网站&#xff1a; 立即访问 P…

Flink学习连载文章9--状态(State)

State state 可以理解为-- 历史计算结果 有状态计算和无状态计算 无状态计算: 不需要考虑历史数据, 相同的输入,得到相同的输出!如:map, 将每个单词记为1, 进来一个hello, 得到(hello,1),再进来一个hello,得到的还是(hello,1) 有状态计算: 需要考虑历史数据, 相同的输入,可…

go和python的遍历对比

Go 和 Python 都有强大的循环控制结构&#xff0c;但它们在实现和行为上有所不同&#xff0c;特别是关于索引变量的管理、迭代器的使用以及如何在循环中修改循环变量。以下是 Go 和 Python 循环的详细差异分析&#xff1a; 1. 循环类型&#xff1a; Go&#xff1a; Go 使用 …

嵌入式硬件面试题【经验】总结----会不断添加更新

目录 引言 一、电阻 1、电阻选型时一般从那几个方面考虑 2、上拉电阻的作用 3、PTC热敏电阻作为电源电路保险丝的工作原理 4、如果阻抗不匹配&#xff0c;有哪些后果 二、电容 1、电容选型一般从哪些方面进行考虑? 2、1uf的电容通常来滤除什么频率的信号 三、三极管…