Git 常用命令大全

ops/2024/12/22 23:16:20/

在这里插入图片描述


🚀 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,你会看到类似下面的冲突标记:
javascript"><<<<<<< 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的核心概念和常用命令,并在实践中不断积累经验,才能更好地应对各种复杂情况。


http://www.ppmy.cn/ops/21453.html

相关文章

网络安全攻击溯源的重要性及挑战

网络安全攻击溯源是一个复杂且至关重要的过程&#xff0c;它涉及对网络攻击事件的来源进行追踪和分析&#xff0c;以便确定攻击者的身份、动机和攻击路径。在IP技术背景下&#xff0c;网络安全攻击溯源更是显得尤为重要&#xff0c;因为IP地址作为网络设备的唯一标识&#xff0…

Linux系统安装Redis7(详细版)

Linux系统安装Redis7 一、windows安装redis二、Linux安装Redis下载redis编辑redis7.conf文件启动redis-server服务如何关闭redis服务设置Redis开机自启动 一、windows安装redis Window 下安装 下载地址&#xff1a;https://github.com/dmajkic/redis/downloads 下载到的Redi…

【数据结构】单链表的尾插法

尾插法是一种在链表末尾插入新元素的方法&#xff0c;它的核心思想是保持链表的尾部指针&#xff08;或称为尾节点&#xff09;&#xff0c;这样可以在常数时间内完成尾部插入操作。尾插法的主要步骤如下&#xff1a; 创建新节点&#xff1a;首先&#xff0c;根据需要插入的数据…

github two-factor authentication是个啥?

最近在逛github时&#xff0c;总是时不时会弹出一下界面&#xff0c;很烦 看到红框里的文字&#xff0c;这明显是强制要求做这个认证&#xff0c;如果不认证4天后账号将不可访问&#xff0c;所以今天花点时间看看怎么做这个认证&#xff0c;点“Enable 2FA now”进入这个界面&a…

新闻 | 电子系协同智能中心与昌平区未来高教园及多所高校开展交流,共话智能无人平台建设

2024年4月8日&#xff0c;清华大学电子工程系在北京昌平两岸共盈科技产业园电子系地空协同智能无人平台基地成功举办“美团杯”智能无人机挑战赛&#xff0c;清华大学电子系党委书记沈渊、昌平区未来城管委会校城融合处处长熊玉川、清华大学团委副书记黄峰等出席。此外来自昌平…

AIGC技术的探讨

一、简介 AIGC&#xff08;人工智能生成内容&#xff09;技术是利用人工智能自动生产内容的一种方式&#xff0c;它在多个领域中的应用不断扩展&#xff0c;同时也带来了伦理和风险问题的考量。 二、技术应用 AIGC技术在各个领域的应用情况广泛&#xff0c;从文本生成到图像…

JVM中的GC如何判断对象可以被回收

引用计数法:每个对象有一个引用计数属性&#xff0c;新增一个引用时计数加1,引用释放时计数减1,计数为0时可以回收, 可达性分析法:从GC Roots开始向下搜索&#xff0c;搜索所走过的路径称为引用链。当一个对象到GC Roots没有任何引|用链相连时&#xff0c;则证明此对象是不可用…

JAVA: Spring Boot加载 Shiro 配置 >>找不到 SecurityManager

在 Spring Boot 应用中集成和配置 Apache Shiro 通常涉及创建一个配置类来设置 SecurityManager&#xff0c;以及定义 Shiro 的 Web 支持和必要的安全策略。下面是使用 Spring Boot 配置 Apache Shiro 的步骤&#xff1a; ### 1. 添加依赖 首先&#xff0c;确保在你的 pom.xml…