Git 常用命令大全

在这里插入图片描述


🚀 Git安装与基础知识学习 🌐

🎯 Git作为一款全球开发者广泛使用的分布式版本控制系统,能够有效帮助团队协作并追踪项目历史版本。接下来,我们将详细展开Git的安装流程、基础命令操作、高级用法以及应对常见问题的方法。

I. 🔧 安装Git

1️⃣ Mac上的安装

  • 通过Homebrew安装 💻

    • 首先,确保你的Mac已安装Homebrew,若未安装,打开终端(Terminal)并运行以下命令来安装Homebrew:
      /bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"
      
    • 安装完成后,利用Homebrew安装Git:
      brew install git
      
  • 直接下载安装包安装 📦

    • 若你更倾向于直接安装,可访问Git官网 https://git-scm.com/download/mac,下载最新版的Git安装包并按提示完成安装过程。

2️⃣ Windows上的安装

  • 通过Chocolatey安装 💻

    • 对于Windows用户,如果你有Chocolatey包管理器,可以在管理员权限的PowerShell中执行以下命令来安装Git:
      Set-ExecutionPolicy Bypass -Scope Process -Force; iex ((New-Object System.Net.WebClient).DownloadString('https://chocolatey.org/install.ps1'))
      choco install git
      
  • 直接下载安装包安装 📦

    • 如果你没有Chocolatey,或者希望手动安装,可以从Git官网 https://git-scm.com/download/win 下载安装程序,然后跟随向导一步步完成Git的安装。

II. 📜 Git基础命令

👶 初始化本地仓库

当你在一个新的项目目录下想创建一个新的Git仓库时,只需运行:

git init

这将在此目录下创建一个.git隐藏文件夹,用于存储版本控制的所有信息。

📝 添加文件到暂存区

要将某个文件或所有修改加入到暂存区,以便后续提交,执行:

git add <file>

如果你想一次性添加所有更改,可以使用:

git add .

提交更改

将暂存区的更改永久记录到版本历史中,需执行提交操作,并附带一条简短明了的提交信息:

git commit -m "描述本次提交的信息"

📡 添加远程仓库

当你需要将本地仓库关联到GitHub或其他远程服务时,需要添加远程仓库地址:

git remote add origin <repository-url>

🚀 推送更改

完成本地提交后,你可以将这些更改推送到远程仓库的指定分支:

git push origin <branch-name>

📥 拉取更新

从远程仓库获取最新的提交并合并到本地,确保你的工作副本是最新的:

git pull origin <branch-name>

📌 分支操作

  • 创建新分支并切换到新分支:
git branch <new-branch-name>
git checkout <new-branch-name>
  • 或者,你可以一步到位地创建并切换新分支:
git checkout -b <new-branch-name>
  • 在你完成特定功能或修复后,需要将分支合并回主分支:
git checkout <main-branch-name>
git merge <new-branch-name>

III. 🧑‍💼 Git高级用法

🕵️‍♂️ 查看提交历史

查看项目的提交历史记录,包括作者、时间戳和提交信息:

git log

还可以结合各种选项定制输出格式。

撤销更改

若想撤消最近的一次提交并恢复至提交前的状态:

git reset --hard HEAD^

请注意,此命令会丢弃所有未提交的更改,慎用!

📌 stash暂存

当需要临时清理工作目录,而又不想提交任何未完成的工作时,可以暂存更改:

git stash

待合适时机,可以恢复之前暂存的更改:

git stash pop

🔍 查找差异

比较不同状态下的文件内容差异:

  • 查看工作区和暂存区的差异:
git diff <file>
  • 查看工作区与最近一次提交之间的差异:
git diff HEAD <file>

IV. 💬 常见问题与解决办法

😱 合并冲突

场景:假设Alice和Bob同时修改了同一行代码,Alice先提交,Bob在拉取并试图合并时遇到了冲突。

# Bob在尝试合并时遇到如下错误信息
Auto-merging src/main.js
CONFLICT (content): Merge conflict in src/main.js
Automatic merge failed; fix conflicts and then commit the result.

解决办法

  1. 打开冲突文件src/main.js,你会看到类似下面的冲突标记:
<<<<<<< HEAD
// Alice的修改
function doSomething() {
    // Alice的代码...
=======
// Bob的修改
function doSomething() {
    // Bob的代码...
>>>>>>> Bob's-commit-hash
  1. 根据实际情况,手动编辑这个文件,选择保留哪一方的修改或者融合两者的修改。
  2. 解决完冲突后,将文件添加到暂存区并提交:
git add src/main.js
git commit -m "Resolved merge conflict in main.js"

🤔 丢失提交

场景:不小心执行了 git reset --hardgit rebase 导致最近的提交丢失。

解决办法

  1. 使用 git reflog 查看历史操作记录,找到丢失提交的SHA码。
git reflog
  1. 假设你找到了丢失的提交SHA码为 abc123def456,可以通过 git cherry-pick 将该提交复制到当前分支。
git cherry-pick abc123def456

💡 忽略特定文件类型

场景:你不想让Git跟踪项目中的某些文件类型,比如IDE配置文件或构建产物。

解决办法

  1. 在项目根目录下创建或编辑.gitignore文件,列出你想要忽略的文件类型或文件路径。
*.idea/
build/
*.log
  1. 已经被Git跟踪的文件需要先从索引中移除,才能开始忽略。
git rm --cached <file-you-want-to-ignore>
git commit -m "Remove <file-you-want-to-ignore> from version control"

以上只是Git日常使用中的一部分常见问题及其解决方案,每个问题都有可能随着具体环境和需求的不同而变化。掌握Git的核心概念和常用命令,并在实践中不断积累经验,才能更好地应对各种复杂情况。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

西湖大学赵世钰老师【强化学习的数学原理】学习笔记1节

强化学习的数学原理是由西湖大学赵世钰老师带来的关于RL理论方面的详细课程&#xff0c;本课程深入浅出地介绍了RL的基础原理&#xff0c;前置技能只需要基础的编程能力、概率论以及一部分的高等数学&#xff0c;你听完之后会在大脑里面清晰的勾勒出RL公式推导链条中的每一个部…

信息系统集成对企业的影响到底有多大?

什么是信息系统集成 系统集成&#xff08;System Integration&#xff09;是指将若干个独立运作的系统或服务联通并整合的过程&#xff0c;旨在将那些存在交集或重复功能的分散模块融合为一个协同工作的整体&#xff0c;以实现效能的最大化和资源的最优配置&#xff0c;避免不…

找不到mfc140u.dll文件如何处理?这三种方法帮你快速修复mfc140u.dll

当你的电脑出现提示&#xff0c;显示找不到mfc140u.dll文件&#xff0c;从而无法继续执行代码&#xff0c;你需要知道如何应对这种情况。今天我们就来详细说明如何解决mfc140u.dll文件丢失的问题&#xff0c;并对该文件进行详细分析。这个文件是Microsoft Visual Studio的一个重…

AI文章写作网站

最强AI文章写作网站——心语流光&#xff08; Super Ai Writer &#xff09; 特点 多轮问答写作&#xff0c;自动携带历史记录进行问答可以自定义携带历史记录的轮数&#xff0c;为0则携带全部历史记录&#xff0c;有效避免token浪费&#xff08;类似coze平台&#xff09;AI生…

【Java网络编程】TCP通信(Socket 与 ServerSocket)和UDP通信的三种数据传输方式

目录 1、TCP通信 1.1、Socket 和 ServerSocket 1.3、TCP通信示例 2、UDP的三种通信&#xff08;数据传输&#xff09;方式 1、TCP通信 TCP通信协议是一种可靠的网络协议&#xff0c;它在通信的两端各建立一个Socket对象 通信之前要保证连接已经建立&#xff08;注意TCP是一…

【06】JAVASE-数组讲解【从零开始学JAVA】

Java零基础系列课程-JavaSE基础篇 Lecture&#xff1a;波哥 Java 是第一大编程语言和开发平台。它有助于企业降低成本、缩短开发周期、推动创新以及改善应用服务。如今全球有数百万开发人员运行着超过 51 亿个 Java 虚拟机&#xff0c;Java 仍是企业和开发人员的首选开发平台。…

从业务经营到企业战略,构建制药企业数字化应用新能力

我国医药的消费正处在一个高速增长的阶段&#xff0c;人口增长、老龄化加剧、经济总体增长、人均消费增长、农村收入提高&#xff0c;这五大因素是医药市场蓬勃发展的动力。在这五大因素的驱动下&#xff0c;我国的医药市场需求将会在未来相当长的时间内保持高速增长。从多个环…

神经网络:手写数字图像识别

一、导入相关库函数 import matplotlib.pyplot as plt import tensorflow as tf import keras import numpy as np 二、载入mnist数据集 使用keras.中的mnist数据集 (train_images, train_labels), (test_images, test_labels)\ keras.datasets.mnist.load_data() 三、测…

在微信上卖化妆品怎样发圈(学会写朋友圈段子卖货很简单)

大家好&#xff0c;我是只说人话&#xff0c;不讲概念&#xff0c;专给创业者们开思维脑洞 今天咱们要分享的内容比较有趣&#xff0c;教你如何写段子故事在朋友圈里做促销活动。 首先我们来看一个硬蹭明星热点的朋友圈案例。发朋友圈的是一位做装修的&#xff0c;在明星结婚的…

Python AI库 Pandas的常见操作的扩展知识

Python AI库 Pandas的常见操作的扩展知识 本文默认读者具备以下技能&#xff1a; 熟悉python基础知识&#xff0c;vscode或其它编辑工具 熟悉表格文件的基本操作 具备自主扩展学习能力 前文中对Pandas的数据结构以及基础操作做了介绍,本文中会在前文的基础上,对常见的操作进…

Python自动化系统6

元素的特征:根据页面设计规则&#xff0c;有些特征是唯一 开发遵循了这个规则 id :类比身份证号―仅限于当前页面 username username 注意:如果id 不是固定的话&#xff0c;就不能使用来定位! xpath: 1、绝对路径&#xff1a;/html/body/div/div/div[1]/a/b --根节点&#xff…

2024公共管理与社会发展国际学术会议(ICPMSD 2024)

2024公共管理与社会发展国际学术会议(ICPMSD 2024) 2024 International Conference on Public Management and Social Development 一、【会议简介】 2024公共管理与社会发展国际学术会议&#xff0c;将汇集全球顶尖学者&#xff0c;展开一场学术盛宴。 在这次会议上&#xff0…

【UE C++】设置游戏模式

问题 我们都知道如何使用蓝图创建一个游戏模式并且在这个游戏模式蓝图中去设置“默认pawn类”、“HUD类”、“玩家控制器类”、“游戏状态类”、“玩家状态类”、“旁观者类”。那么如何使用C完成该操作呢&#xff1f; 步骤 1. 首先创建“GameMode”、“GameState”、“HUD”…

如何用二维码实现现代仓库管理?

随着科技的进步&#xff0c;二维码技术逐渐应用与各个领域&#xff0c;其中在仓库管理中的应用也日益广泛。 那话不多说&#xff0c;我们直接来看如何用二维码实现现代仓库管理 简道云仓库管理模板&#xff0c;可以点击安装配合阅读&#xff1a;https://www.jiandaoyun.com 二…

Oracle集群ORA-03113:end-of-file on communication channel

一、问题场景描述 今天Oracle集群要更新各数据库的数据&#xff0c;折腾的启动不了了&#xff1a; --》数据量比较大&#xff0c;数据泵方式导出的dmp文件 准备导入集群 --》由于之前的生产数据库数据比较少&#xff0c;需要增大表空间。 --》于是在sqlplus命令窗口&#xff0c…

暗区突围端游海外版|暗区突围免费加速器有吗 免费加速器推荐

游戏中玩家可以创建男性或女性角色&#xff0c;可以通过选择脸型、发型、发色对人物形象进行调整&#xff1b;在进入游戏后&#xff0c;除人物性别不能修改&#xff0c;脸型、发型、发色都可以进行调整。除此之外可以在衣橱中对角色的上衣、手套、裤子、鞋子、帽子进行更换。游…

Leetcode—1017. 负二进制转换【中等】(string列表初始化、反向迭代器)

2024每日刷题&#xff08;120&#xff09; Leetcode—1017. 负二进制转换 实现代码 class Solution { public:string baseNeg2(int n) {string ans;while(n ! 0) {ans to_string(n & 1);n -(n >> 1);}return ans.empty() ? "0": string{ans.rbegin(),…

R语言详解二

一&#xff0c;列表详解 创建一个列表 > myList<-list(id2,name"张三",age20) > myList $id [1] 2$name [1] "张三"$age [1] 20 获取第一个元素 > myList[[2]] [1] "张三" 获取第一个子列表 > myList[2] $name [1] "张…

百度 测试|测试开发 面试真题|面经 汇总

百度测开 开发测试工程师 提前批一二三面面经 事业群&#xff1a;MEG base&#xff1a;北京 一面&#xff1a;2023.8.12 时长&#xff1a;50min 自我介绍 个人项目&#xff0c;我的项目是围绕着学校课程的项目来的&#xff0c;面试官就让我介绍这门课讲了些什么 &#xff…

信息化项目总体计划书(Word)

项目开发计划包括项目描述、项目组织、成本预算、人力资源估算、设备资源计划、沟通计划、采购计划、风险计划、项目过程定义及项目的进度安排和里程碑、质量计划、数据管理计划、度量和分析计划、监控计划和培训计划等。 软件全套精华资料包清单部分文件列表&#xff1a; 工作…