Git常用操作指令

作者:stu_kk日期:2026/2/7

最近给公司小伙伴安排了一下git培训,写了个常用指令,记录一下

一、配置与初始化(首次使用/新建仓库)

指令功能说明
git config --global user.name "你的姓名"配置全局用户名(会显示在提交记录中)
git config --global user.email "你的公司邮箱"配置全局用户邮箱
`git config --list查看配置
mkdir git-demo创建项目文件夹(系统命令,Git初始化前准备)
cd git-demo进入项目文件夹(系统命令)
git init初始化本地Git仓库(生成隐藏的.git 文件夹)

二、本地核心操作(文件修改/提交/历史查看)

指令功能说明
touch README.md创建文件(系统命令,用于测试Git操作)
echo "# Git Demo" >> README.md编辑文件内容(系统命令)
git status查看文件状态(红色=未暂存,绿色=已暂存)
git add <文件名>将指定文件从工作区添加到暂存区(例:git add README.md )
git commit -m "提交信息"将暂存区文件提交到本地仓库(提交信息需规范,例:feat: 初始化README )
git log查看详细提交历史(按q 退出)
git log --oneline查看简洁提交历史(推荐日常使用)
git checkout <文件名>恢复未提交的误删文件(从本地库恢复)
git commit --amend修改最后一次提交的信息(提交信息写错时使用)

三、版本回滚

指令功能说明
git reset --hard HEAD^强制回滚到上一个版本(HEAD^ 表示上一版)
git reset --hard <版本号>强制回滚到指定版本(版本号从git log /git log --oneline 获取)
注意强制回滚会丢弃当前未提交的修改,务必谨慎使用!

四、分支操作(团队协作核心)

指令功能说明
git branch查看本地所有分支
git checkout -b <分支名>创建并切换到新分支(例:git checkout -b feature/login )
git checkout <分支名>切换到已有分支(例:git checkout main )
git merge <分支名>合并指定分支到当前分支(例:git merge feature/login )
git branch -d <分支名>合并后删除分支(例:git branch -d feature/login )
分支命名规范功能开发:feature/功能名 (例:feature/payment );Bug修复:fix/bug描述 (例:fix/button-fix )

五、远程同步(与团队共享代码)

指令功能说明
git remote add origin <远程仓库URL>关联本地仓库与远程仓库(例:Gitee/GitHub仓库URL)
git clone <远程仓库URL>克隆远程仓库到本地(首次获取远程代码时使用)
git pull拉取远程仓库最新代码(避免冲突,修改前优先执行)
git push -u origin <分支名>推送本地分支代码到远程仓库(例:git push -u origin main )
协作黄金口诀先pull再修改,修改先add,提交写备注,分支分清楚

六、冲突处理(代码“撞车”时)

指令功能说明
步骤1手动编辑冲突文件:保留需要的逻辑,删除冲突标记(<<<<<<< 、======= 、>>>>>>> )
git add <冲突文件名>标记冲突已解决,将文件加入暂存区
git commit -m "fix: 解决合并冲突,保留核心逻辑"提交解决冲突后的代码
git push推送解决冲突后的代码到远程仓库

六、补充模块:暂存未提交修改(git stash 系列指令)

指令功能说明
git stash暂存当前工作区和暂存区中未提交的修改(不包含未跟踪文件),使工作区恢复干净状态,方便切换分支或处理其他任务
git stash save "备注信息"暂存时添加备注(推荐),便于后续区分不同暂存内容(例:git stash save "未完成的支付功能开发" )
git stash list查看所有暂存记录(格式:stash@{n}: On 分支名: 备注信息 ,n为暂存序号,从0开始)
git stash apply stash@{n}恢复指定序号的暂存修改(n可省略,默认恢复最新的stash@{0} ),暂存记录不会删除(例:git stash apply stash@{1} )
git stash pop stash@{n}恢复指定序号的暂存修改,同时删除该暂存记录(常用,恢复后清理无用暂存)
git stash drop stash@{n}仅删除指定序号的暂存记录(无需恢复时清理)
git stash clear清空所有暂存记录(谨慎使用,不可恢复)
git stash show stash@{n}查看指定暂存记录的修改差异(显示文件变更摘要)
核心使用场景:
  1. 开发中需要临时切换分支(如修复紧急Bug),但当前修改未完成不想提交,用git stash暂存后切换,返回后用pop恢复继续开发;
  2. 拉取远程代码(git pull)前,本地有未提交修改可能冲突,暂存后拉取,再恢复修改合并。

提交信息规范(辅助指令使用,提升协作效率)

  • feat: 新增功能特性(例:feat: 新增登录功能
  • fix: 修复代码缺陷或Bug(例:fix: 修复按钮点击无响应
  • docs: 仅修改文档说明(例:docs: 更新API文档
  • style: 仅修改格式(不影响逻辑)(例:style: 调整代码缩进

七、IDEA操作GIT(不同版本的IDEA界面可能稍有不同)

  1. 克隆项目

2. 拉取项目最新代码、 提交代码、推送代码

3、新建分支 切换分支

4、合并分支


Git常用操作指令》 是转载文章,点击查看原文


相关推荐


Prometheus+Grafana构建云原生分布式监控系统(十)_prometheus的服务发现机制(一)
牛奶咖啡132026/1/29

Prometheus+Grafana构建云原生分布式监控系统(九)_pushgateway的使用https://blog.csdn.net/xiaochenXIHUA/article/details/157392956 一、prometheus的服务发现机制  1.1、prometheus的服务发现机制概述         prometheus是基于拉(pull)模式抓取监控数据,首先要能够发现需要监控的目标对象target,那么prometheus如何获监控目标呢?有两种方式【静态手动配


Polyfill方式解决前端兼容性问题:core-js包结构与各种配置策略
漂流瓶jz2026/1/20

简介 在之前我介绍过Babel:解锁Babel核心功能:从转义语法到插件开发,Babel是一个使用AST转义JavaScript语法,提高代码在浏览器兼容性的工具。但有些ECMAScript并不是新的语法,而是一些新对象,新方法等等,这些并不能使用AST抽象语法树来转义。因此Babel利用core-js实现这些代码的兼容性。 core-js是一个知名的前端工具库,里面包含了ECMAScript标准中提供的新对象/新方法等,而且是使用旧版本支持的语法来实现这些新的API。这样即使浏览器没有实现标准


一文搞懂机器学习中的特征降维!
aicoting2026/1/12

推荐直接网站在线阅读:aicoting AI算法面试学习在线网站 特征工程(Feature Engineering) 是机器学习流程中将原始数据转换为适合模型学习的特征的关键步骤。它直接决定了模型能否高效捕捉数据中的规律。好的特征可以显著提升模型性能,而差的特征即使模型再复杂也难以取得好效果。 特征工程的核心目标是: 提取有效信息:将原始数据中有价值的信号转化为模型可以理解的特征; 减少冗余与噪声:去掉无关或多余的特征,使模型更简洁、更泛化; 增强表达能力:通过构造、组合或降维生成新的特征,


Day 12:Git配置详解:用户信息、编辑器、颜色等配置
CNRio2026/1/4

“你有没有遇到过这样的尴尬:提交代码时,Git显示’Author: Unknown’,然后你发现是自己写的代码,却不知道是谁提交的?别担心,这就像你写了一封信,却没写署名一样!” 🌟 为什么说Git配置是"代码身份证"? 想象一下,你正在写一本小说,每章都署名"匿名作者"。读者会怎么想?他们可能会怀疑这本书是不是真的由你写的。Git配置就是你的"代码身份证",它告诉世界"这代码是我写的"。 正如《Pro Git》中所说: “Git的配置系统是分层的,有三个层次:系统级、全局级和本地级。系统


LeetCode 热题100 --- 双指针专区
谎言西西里2025/12/26

283. 移动零 - 力扣(LeetCode) 题目分析: 题目要求将数组 nums 中所有 0 移动至数组末尾,同时保持其他非零元素的相对顺序不变,并且要求在原数组上进行操作。 核心要求: 0 要移动至数组末尾 非零元素相对位置不变 在原数组上进行操作 解法一(暴力使用数组方法) 遍历数组将其中所有为 0 的数直接使用splice删除并且记录 0 的个数,最后通过push填入“移动”的 0 var moveZeroes = function(nums) { let n = 0;


【大前端】【Android】 Android 手机上导出已安装 App 的 APK
柯南二号2025/12/17

根据是否有 root / adb / 仅手机操作,常见有 4 种靠谱方式。按「实用度 + 成本」整理👇 一、最推荐:ADB 导出(无需 Root,最稳定)⭐️ 适合开发者、抓包、逆向、分析三方 APK 1️⃣ 开启 USB 调试 设置 → 关于手机 → 连续点击“版本号” → 开发者模式 开发者选项 → USB 调试 2️⃣ 找到 APK 路径 adb shell pm list packages | grep wechat 例如: package:com.tence


Agent 入门科普:从"人工智障"到"数字打工人"的进化史
无限大62025/12/9

🤖 Agent 入门科普:从"人工智障"到"数字打工人"的进化史 大家好,欢迎来到无限大的博客,这个专栏是新开的,打算讲一讲Agent,其实早就有学习的打算了 近期在逛github的时候看到一个高star项目,叫做Hello-Agents,项目地址是[github.com/datawhalech…] 我的文章也是参考了这个内容写的,这个系列更新比较慢,因为我也是边学边写的,所以会比较慢,但是我会尽量写的详细一些,用更多贴近生活的抽象案例来讲解,希望能帮助到大家 引言:当 AI 开始自己"打


为什么C语言拒绝函数重载?非要重载怎么做?
码事漫谈2025/11/29

在我们学习C++、Java或C#时,函数重载(Function Overloading)是一个再自然不过的概念:允许两个或多个函数使用相同的名字,只要它们的参数列表(参数的类型、个数或顺序)不同即可。编译器会根据调用时传入的实参,自动选择最匹配的那个函数。 然而,当我们回到C语言的世界,这条规则却失效了。如果你定义了两个同名的函数,即使参数列表不同,编译器也会毫不留情地报出一个“重定义”错误。 那么,为什么C语言的设计者,要“剥夺”这个看似非常实用的特性呢? 答案并非“不能”,而是“不为”。这背


【C++】模拟实现 红黑树(RBTree)
yuuki2332332026/2/16

前言: 在掌握 AVL 树的严格平衡机制后,我们发现其虽能将树高严格控制在 O(logN),但「高度差≤1」的强约束也带来了明显代价:插入 / 删除操作中频繁的旋转(最多两次双旋)大幅增加了写操作的开销,且每个节点需额外存储平衡因子和父指针,空间利用率较低。 为解决这一问题,红黑树(Red-Black Tree)作为一种近似平衡的二叉搜索树应运而生 —— 它放弃了 AVL 树 “严格平衡” 的要求,转而通过「节点颜色标记 + 5 条核心规则」实现 “黑高一致” 的弱平衡,将任意根到叶子的路径


React Native 开发环境准备
zh_xuan2026/2/24

一、环境准备 我的环境: 二、建立独立RN工程 1、初始化创建工程 npx react-native init RNApp --version 0.73.4 --skip-install 这个命令提示: ��️ The `init` command is deprecated. E:\android\projects\RNDemo4>cd RNApp - Switch to npx @react-native-community/cli init f

首页编辑器站点地图

本站内容在 CC BY-SA 4.0 协议下发布

Copyright © 2026 XYZ博客