Git基础知识与常用命令指南

这是一个Git基础知识和常用命令的简要指南,涵盖了日常开发中最常用的操作。你可以将这个指南保存下来,作为日常工作的参考。
image.png

目录

  • 基础篇
    • 1. Git基本概念
    • 2. 配置Git
    • 3. 创建仓库
    • 4. 基本的工作流程
    • 5. 分支操作
    • 6. 查看历史
    • 7. 撤销更改
    • 8. 远程仓库操作
  • Git进阶知识与技巧指南
    • 1. 分支管理策略
      • Git Flow
      • GitHub Flow
    • 2. 高级分支操作
    • 3. 撤销操作
    • 4. 储藏(Stash)
    • 5. 子模块(Submodule)
    • 6. 打标签
    • 7. 使用别名
    • 8. 使用 Git Hooks
    • 9. 使用 Git Large File Storage (LFS)
    • 10. 高级日志查看
  • 总结

学习Git的一些建议:

  1. 先理解基本概念,如仓库、分支、提交等。
  2. 从基本的工作流程开始练习:修改文件、暂存、提交、推送。
  3. 尝试创建和管理分支,这是Git的强大特性之一。
  4. 学会查看和理解项目历史,使用git loggit diff
  5. 熟悉如何处理冲突,这在团队协作中很重要。
  6. 多加练习,可以创建一个测试仓库来尝试各种命令。

基础篇

1. Git基本概念

image.png

  • 仓库(Repository): 用来存放项目代码的地方
  • 分支(Branch): 独立的开发线
  • 提交(Commit): 保存当前工作进度
  • 远程仓库(Remote): 托管在网络上的项目仓库

2. 配置Git

image.png

git config --global user.name "Your Name"
git config --global user.email "your_email@example.com"

3. 创建仓库

git init  # 在当前目录初始化一个新的Git仓库
git clone <url>  # 克隆一个远程仓库到本地

4. 基本的工作流程

image.png

git status  # 查看仓库状态
git add <file>  # 将文件添加到暂存区
git commit -m "commit message"  # 提交更改
git push origin <branch>  # 将本地更改推送到远程仓库
git pull  # 从远程仓库拉取更新

5. 分支操作

image.png

git branch  # 列出所有本地分支
git branch <branch-name>  # 创建新分支
git checkout <branch-name>  # 切换到指定分支
git merge <branch-name>  # 合并指定分支到当前分支

6. 查看历史

image.png

git log  # 查看提交历史
git diff  # 查看未暂存的更改

7. 撤销更改

git checkout -- <file>  # 撤销对文件的修改
git reset HEAD <file>  # 取消暂存文件
git revert <commit>  # 撤销某次提交

8. 远程仓库操作

image.png

git remote add origin <url>  # 添加远程仓库
git fetch  # 从远程仓库获取最新更改但不合并
git pull  # 拉取远程更改并合并到当前分支
git push origin <branch>  # 推送本地分支到远程仓库

记住,实践是学习Git的最好方法。尝试在一个测试仓库中使用这些命令,会帮助你更好地理解Git的工作原理。
image.png

Git进阶知识与技巧指南

  • 分支管理策略:了解并在实际项目中尝试使用Git Flow或GitHub Flow。
  • 练习高级分支操作:尝试使用rebase和cherry-pick,理解它们与merge的区别。
  • 熟悉撤销操作:理解reset和revert的不同,谨慎使用,特别是在共享分支上。
  • 利用stash功能:在需要快速切换任务时,stash非常有用。
  • 了解子模块:如果你的项目依赖其他Git仓库,子模块会很有帮助。
  • 使用标签:为重要的版本打标签,便于快速定位。
  • 设置别名:为常用命令设置别名,提高效率。
  • 探索Git Hooks:尝试使用pre-commit hook来自动运行代码检查。
  • 考虑使用Git LFS:如果项目中有大文件,Git LFS可以帮助管理。
  • 学会高效查看日志:使用不同的log选项来更好地理解项目历史。
    这些高级特性需要在实际项目中反复练习才能熟练掌握。
    你可以创建一个练习项目,逐个尝试这些功能。

1. 分支管理策略

Git Flow

一种常用的分支管理策略,包括以下分支:

  • master: 主分支,存放稳定版本
  • develop: 开发分支
  • feature: 功能分支
  • release: 发布分支
  • hotfix: 热修复分支

这个图表展示了一个基于 Git Flow 的简化工作流。主要特点包括:

  • 主分支(main):只包含稳定的、可发布的代码。
  • 开发分支(develop):日常开发的集成分支。
  • 特性分支(feature):用于开发新功能。
  • 发布分支(未显示):用于准备新的生产版本。
  • 热修复分支(未显示):用于快速修复生产问题。

GitHub Flow

一种更简单的工作流:

  • 只有一个长期分支master
  • 其他都是短期的功能分支

2. 高级分支操作

git rebase <branch>  # 变基操作,将当前分支移植到指定分支之上
git cherry-pick <commit>  # 将指定的提交应用到当前分支

3. 撤销操作

git reset --hard <commit>  # 将HEAD重置到指定提交
git revert <commit>  # 创建一个新的提交来撤销指定提交的更改

4. 储藏(Stash)

git stash  # 暂时储藏当前工作目录的更改
git stash list  # 查看所有储藏
git stash apply  # 应用最近的储藏
git stash drop  # 删除最近的储藏

5. 子模块(Submodule)

git submodule add <url>  # 添加子模块
git submodule init  # 初始化子模块
git submodule update  # 更新子模块

6. 打标签

git tag <tagname>  # 创建轻量标签
git tag -a <tagname> -m "message"  # 创建附注标签
git push origin <tagname>  # 推送标签到远程

7. 使用别名

.gitconfig 文件中设置别名可以简化常用命令:

[alias]
    co = checkout
    br = branch
    ci = commit
    st = status

8. 使用 Git Hooks

Git hooks 是在 Git 执行特定事件时自动运行的脚本,位于 .git/hooks 目录下。常用的 hooks 包括:

  • pre-commit: 提交前运行
  • post-commit: 提交后运行
  • pre-push: 推送前运行

9. 使用 Git Large File Storage (LFS)

对于大文件的版本控制,可以使用 Git LFS:

git lfs install  # 安装 Git LFS
git lfs track "*.psd"  # 追踪所有 PSD 文件

10. 高级日志查看

git log --graph --oneline --all  # 查看分支图
git reflog  # 查看所有操作历史

这些进阶技巧可以帮助你更高效地使用Git,特别是在复杂的项目或团队协作中。随着实践,你会逐渐掌握这些技巧,并在日常工作中灵活运用。

总结

Git 是一个非常强大的版本控制系统,虽然短时间无法全面掌握,但我们可以学习基础知识和常用命令。以下是一个简单的学习大纲:

  1. Git 基础概念 (1小时)

    • 什么是版本控制
    • Git 的历史和优势
    • 仓库、提交、分支的概念
  2. 安装和配置 Git (30分钟)

    • 在你的操作系统上安装 Git
    • 配置用户名和邮箱
  3. 创建和克隆仓库 (1小时)

    • 使用 git init 创建新仓库
    • 使用 git clone 克隆现有仓库
  4. 基本的 Git 工作流程 (2小时)

    • 使用 git status 查看仓库状态
    • 使用 git add 暂存更改
    • 使用 git commit 提交更改
    • 使用 git log 查看提交历史
  5. 分支操作 (2小时)

    • 创建分支 git branch
    • 切换分支 git checkout
    • 合并分支 git merge
  6. 远程仓库操作 (2小时)

    • 添加远程仓库 git remote add
    • 推送到远程 git push
    • 从远程拉取 git pull
  7. 实践项目 (剩余时间)

    • 创建一个小项目,运用学到的 Git 命令
    • 模拟团队协作,创建分支、合并更改等
  8. 额外资源和回顾 (30分钟)

    • 回顾学习内容
    • 推荐进阶学习资源

这个计划涵盖了 Git 的基础知识。

如果你想要更详细的解释或者关于某个特定部分的更多信息,请随时告诉我。欢迎在评论区交流~

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

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

相关文章

重温react-13(嵌套路由和重定向等)

重定向和404 import React from react; import { Routes, Route, Link,NavLink ,Navigate} from react-router-dom; import Home from ./Home/Home import About from ./About/About import News from ./News/News import NotFound from ./NotFound/NotFound; export default …

数据结构——单向循环链表

文章目录 1. 概念 2. 区别 2.1 结构区别 2.2 访问方式区别 2.3 优缺点对比 3. 流程 4. 基本操作 5. 代码示例 1. 概念 单向循环链表是一种特殊的单链表&#xff0c;其中最后一个节点的后继指针指向头节点&#xff0c;形成一个环。单向循环链表适合用于需要循环访问数据…

Qt 基础组件速学 鼠标和键盘事件

学习目标&#xff1a; 鼠标事件和键盘事件应用 前置环境 运行环境:qt creator 4.12 学习内容和效果演示&#xff1a; 1.鼠标事件 根据鼠标的坐标位置&#xff0c;做出对应的事件。 2.键盘事件 根据键盘的输入做出对应操作 详细主要代码 1.鼠标事件 #include "main…

C++新特性

C新特性主要体现在语法改进和标准库扩充两个方面。以下是一些主要的C新特性&#xff1a; 语法改进 统一的初始化方法&#xff1a;C11扩大了用大括号括起的列表&#xff08;初始化列表&#xff09;的使用范围&#xff0c;使其可用于所有的内置类型和用户自定义的类型。这种定义…

vue.js微商城后台管理系统

一.需要运行的效果 20240701-231456 二.代码&#xff08;解析&#xff09; 首先&#xff0c;为项目添加依赖&#xff1a; yarn add element-plus --save yarn vue-router4 --save 新建一个项目包&#xff0c;然后命名为商品管理&#xff0c;在components中新建几个vue文件。 …

全新UI自助图文打印系统小程序源码 PHP后端 附教程

最新自助图文打印系统和证件照云打印小程序源码PHP后端&#xff0c;为用户用户自助打印的服务&#xff0c;包括但不限于文档、图片、表格等多种格式的文件。此外&#xff0c;它们还提供了诸如美颜、换装、文档打印等功能&#xff0c;以及后台管理系统&#xff0c;方便管理员对打…

TreeMap、HashMap 和 LinkedHashMap 的区别

TreeMap、HashMap 和 LinkedHashMap 的区别 1、HashMap2、LinkedHashMap3、TreeMap4、总结 &#x1f496;The Begin&#x1f496;点点关注&#xff0c;收藏不迷路&#x1f496; 在 Java 中&#xff0c;TreeMap、HashMap 和 LinkedHashMap 是三种常用的集合类&#xff0c;它们在…

Ubuntu配置GitHub(第一次clone/push)

文章目录 1. 安装Git&检查连接2. 注册GitHub3. 生成&GitHub添加SSH3.1. 检查&删除已有id_rsa3.2. 生成SSH3.3. GitHub添加id_rsa.pub SSH3.4. 检查SSH 4. 继续开发可以参考参考 1. 安装Git&检查连接 安装 sudo apt-get install git检查SSH连接 ssh -T gitgi…

Qt 基础组件速学 事件过滤器

学习目标&#xff1a;理解事件过滤器 前置环境 运行环境:qt creator 4.12 学习内容和效果演示&#xff1a; Qt 提供了事件过滤器的机制,允许我们在事件到达目标对象之前对事件进行拦截和处理。这在以下情况下非常有用: 全局事件处理: 我们可以在应用程序级别安装一个事件过…

数据结构——(双)链表

文章目录 1. 定义 2. 双链表和单链表的区别 3. 代码示例 3.1 双链表节点和结构定义 3.2 初始化双链表 3.3 返回双链表的长度 3.4 在指定位置插入元素 3.5 在末尾插入元素 3.6 删除指定位置的元素并返回被删除的元素 3.7 删除末尾元素 3.8 获取指定位置的元素 3.9 修…

【IT领域新生必看】探索Java中的对象创建:深入理解`new`与`clone`的对比

文章目录 引言什么是new关键字&#xff1f;使用new关键字的基本语法示例&#xff1a; 什么是clone方法&#xff1f;使用clone方法的基本语法示例&#xff1a; new与clone的区别内存分配与初始化调用方式适用场景性能 new关键字的优缺点优点缺点 clone方法的优缺点优点缺点 深入…

机器学习---线性回归

1、线性回归 例如&#xff1a;对于一个房子的价格&#xff0c;其影响因素有很多&#xff0c;例如房子的面积、房子的卧室数量、房子的卫生间数量等等都会影响房子的价格。这些影响因子不妨用 x i x_{i} xi​表示&#xff0c;那么房价 y y y可以用如下公式表示&#xff1a; y …

【贪心 堆 优先队列】502. IPO

本文涉及知识点 贪心 堆 优先队列 LeetCode502. IPO 假设 力扣&#xff08;LeetCode&#xff09;即将开始 IPO 。为了以更高的价格将股票卖给风险投资公司&#xff0c;力扣 希望在 IPO 之前开展一些项目以增加其资本。 由于资源有限&#xff0c;它只能在 IPO 之前完成最多 k…

评价ChatGPT与强人工智能的未来

在人工智能领域&#xff0c;ChatGPT的出现无疑是一个里程碑事件。它不仅展示了自然语言处理技术的巨大进步&#xff0c;也引发了人们对于强人工智能&#xff08;AGI&#xff09;的无限遐想。本文将从多个角度评价ChatGPT&#xff0c;并探讨强人工智能距离我们还有多远。 ChatGP…

【Leetcode笔记】406.根据身高重建队列

文章目录 1. 题目要求2.解题思路 注意3.ACM模式代码 1. 题目要求 2.解题思路 首先&#xff0c;按照每个人的身高属性&#xff08;即people[i][0]&#xff09;来排队&#xff0c;顺序是从大到小降序排列&#xff0c;如果遇到同身高的&#xff0c;按照另一个属性&#xff08;即p…

鸿蒙开发:Universal Keystore Kit(密钥管理服务)【密钥导入介绍及算法规格】

密钥导入介绍及算法规格 如果业务在HUKS外部生成密钥&#xff08;比如应用间协商生成、服务器端生成&#xff09;&#xff0c;业务可以将密钥导入到HUKS中由HUKS进行管理。密钥一旦导入到HUKS中&#xff0c;在密钥的生命周期内&#xff0c;其明文仅在安全环境中进行访问操作&a…

类继承-多继承虚继承

#include<iostream> using namespace std; class A1 { public:int a 10;}; class A2 { public:int b 20; }; class B :public A1, public A2 { public:int c 30; }; int main(){B b;cout << b.a << b.b << b.c << endl;return 0; } 如果基类…

十五、小型电脑没有数字键及insert,怎么解决IDEA快速插入getset构造这些方法

&#x1f33b;&#x1f33b;目录 一、小型电脑没有数字键及insert&#xff0c;怎么解决IDEA快速插入getset构造这些方法 一、小型电脑没有数字键及insert&#xff0c;怎么解决IDEA快速插入getset构造这些方法 解决&#xff1a; 1.winR打开搜索 2.osk回车 屏幕就出现了这样的一…

windows USB 设备驱动开发- 不同模型下的控制传输

在不同的模型下&#xff0c;USB控制传输会有不同的特点&#xff0c;但是任何控制传输的目标都始终是默认端点。 接收者是设备的实体&#xff0c;其信息&#xff08;描述符、状态等&#xff09;是主机感兴趣的。请求可进一步分为&#xff1a;配置请求、功能请求和状态请求。 发…

二刷力扣——单调栈

739. 每日温度 单调栈应该从栈底到栈顶 是递减的。 找下一个更大的 &#xff0c;用递减单调栈&#xff0c;就可以确定在栈里面的每个比当前元素i小的元素&#xff0c;下一个更大的就是这个i&#xff0c;然后弹出并记录&#xff1b;然后当前元素i入栈&#xff0c;仍然满足递减…