Git的详细使用方法
Git 是一个分布式版本控制系统,用于跟踪和管理代码的变更。以下是 Git 的详细使用方法:
1. 安装 Git
-
Windows:从 Git 官网 下载安装包。
-
Linux(Ubuntu/Debian)
sudo apt install git -
macOS:
-
使用 Homebrew。
brew install git
验证安装
git --version
2. 配置用户信息
首次使用
首次使用时,Git 前需配置全局用户名和邮箱:
git config --global user.name "Your Name"
git config --global user.email "your.email@example.com"
查看配置
git config --list
3. 创建仓库
初始化新仓库
git init
克隆现有仓库
git clone https://github.com/user/test.git
4. 基础操作
修改文件
在工作目录中修改或新增文件。
添加到暂存区
git add <file> # 添加单个文件
git add . # 添加所有修改
提交到本地仓库
git commit -m "说明"
查看状态
git status
查看提交历史
git log # 完整的提交历史
git log --oneline # 简单的提交历史
git log --graph # 图形化分支历史
5. 分支管理
创建分支
git branch <branch-name>
切换分支
git checkout <branch-name>
# 或创建并切换到新分支
git checkout -b <branch-name>
合并分支
git checkout master
git merge <branch-name>
删除分支
git branch -d <branch-name> # 删除本地分支
git push origin --delete <branch-name> # 删除远程分支
解决冲突
手动编辑冲突文件后,执行 git add 和 git commit。
6. 远程仓库
-
关联远程仓库
git remote add origin https://github.com/user/test.git -
查看远程仓库
git remote -v -
推送代码
git push origin <branch-name> # 首次推送时指定分支: git push -u origin <branch-name> -
拉取代码
git pull origin <branch-name> # 拉取并合并 git fetch origin # 仅下载远程变更
7. 高级操作
撤销更改
-
撤销工作区修改
git checkout -- <file> -
撤销暂存区修改
git reset HEAD <file> -
回退到某次提交
git reset --hard <commit-id> # 彻底回退(请慎用) git revert <commit-id> # 生成新提交以撤销旧提交
标签管理
-
创建标签
git tag v1.0.0 git tag -a v1.0.0 -m "版本说明" -
推送标签到远程
git push origin --tags
暂存修改
git stash # 暂存当前修改
git stash pop # 恢复暂存的修改
比较差异
git diff # 工作区与暂存区的差异
git diff --staged # 暂存区与最新提交的差异
8. 协作流程(示例)
克隆仓库
git clone https://github.com/user/test.git
创建新分支开发
git checkout -b feature/new-feature
开发完成后提交
git add .
git commit -m "版本说明"
推送分支到远程
git push origin feature/new-feature
Pull Request(PR)或 Merge Request(MR)
在 GitHub/Gitee 上发起 Pull Request(PR)或 Merge Request(MR)。
合并分支
审核通过后合并到主分支(如 master)。
9. 配置与别名
忽略文件
在项目根目录创建 .gitignore,列出需忽略的文件/目录(如 node_modules/, .env)。
设置别名
设置别名可以简化命令
git config --global alias.co checkout
git config --global alias.br branch
10. 常见问题
提交到错误分支
使用 git reset 回退提交,再切换到正确分支提交。
误删分支
通过 git reflog 查找提交记录恢复。
相关文章:
Git的详细使用方法
Git 是一个分布式版本控制系统,用于跟踪和管理代码的变更。以下是 Git 的详细使用方法: 1. 安装 Git Windows:从 Git 官网 下载安装包。 Linux(Ubuntu/Debian) sudo apt install git macOS: 使用 Homebr…...
在 Windows 上使用 choco 安装 mkcert 并配置 Vue 运行HTTPS
解决在Windows上使用Vue本地运行HTTPS的问题,vue-cli或vite都可以使用 步骤 1:确认 Chocolatey 是否已安装 1. 检查 choco 命令是否可用 打开 PowerShell(管理员权限),输入: choco -v如果显示版本号(如…...
spring声明式事务原理01-调用第1层@Transactional方法(事务访问入口)
文章目录 【README】【步骤1】UserAppService调用userSupport.saveNewUser()【步骤2】获取到TransactionInterceptor【步骤3】chain不为空,接着执行CglibMethodInvocation#proceed方法【补充】AopContext作用 【步骤4】CglibMethodInvocation#proceed方法【步骤5】调…...
Qt-D指针与Q指针的设计哲学
文章目录 前言PIMLP与二进制兼容性D指针Q指针优化d指针继承Q_D和Q_Q 前言 在探索Qt源码的过程中会看到类的成员有一个d指针,d指针类型是一个private的类,这种设计模式称为PIMPL(pointer to implementation),本文根据Q…...
数据结构——单链表list
前言:大家好😍,本文主要介绍数据结构——单链表 目录 一、单链表 二、使用步骤 1.结构体定义 2.初始化 3.插入 3.1 头插 3.2 尾插 3.3 按位置插 四.删除 4.1头删 4.2 尾删 4.3 按位置删 4.4按值删 五 统计有效值个数 六 销毁…...
java 的标记接口RandomAccess使用方法
在 Java 中,RandomAccess 是一个标记接口(marker interface),用于标识实现该接口的 List 实现类支持快速(通常是常数时间复杂度 O(1))的随机访问。常见的实现类包括 ArrayList,而不包括 LinkedL…...
基于PHP的网店进销存管理系统(源码+lw+部署文档+讲解),源码可白嫖!
摘要 相比于以前的传统进销存管理方式,智能化的管理方式可以大幅降低进销存管理的运营人员成本,实现了进销存管理的标准化、制度化、程序化的管理,有效地防止了商品信息及仓库信息的随意管理,提高了信息的处理速度和精确度&#…...
Vue3 Pinia $subscribe localStorage的用法 Store的组合式写法
Vue3 Pinia $subscribe 可以用来监视Stroe数据的变化 localStorage的用法 localStorage中只能存字符串,所有对象要选转成json字符串 定义store时,从localStorage中读取数据talkList可能是字符串也可能是空数组 Store的组合式写法 直接使用reactiv…...
【PHP】获取PHP-FPM的状态信息
文章目录 一、前言二、环境三、过程1)修改PHP-FPM配置文件2)修改Nginx配置文件3)访问页面4)修改状态页面端口 一、前言 PHP-FPM内置有一个状态页面,通过这个页面可以获取到FPM的一些状态信息(见下图&#…...
(性能测试)性能测试工具 2.jmeter的环境搭建 3jmeter元件和4使用实例 5jmeter元件和参数化
目录 性能测试工具 性能测试工具 jemeter环境搭建 jmeter的常用目录介绍 jmeter修改语言和主题--jmeter界面的汉化 jmeter元件 jmeter元件和组件的介绍 jmeter的作用域原则 jmeter的执行顺序 案例:执行顺序 jmeter使用案例 jmeter线程组的介绍 jmeter…...
Java 大视界 -- 基于 Java 的大数据实时流处理中的窗口操作与时间语义详解(135)
💖亲爱的朋友们,热烈欢迎来到 青云交的博客!能与诸位在此相逢,我倍感荣幸。在这飞速更迭的时代,我们都渴望一方心灵净土,而 我的博客 正是这样温暖的所在。这里为你呈上趣味与实用兼具的知识,也…...
数据库的基本知识
目录 一、创建数据库和数据表1.1 创建数据库相关代码1.2 创建数据表1.3 约束条件1.3.1 主键约束1.3.2 非空约束1.3.3 唯一性约束1.3.4 默认约束1.3.5 自增字段 1.4 手工建表 二、数据查询功能2.1 sql 查询的7个关键词2.1.1 select2.1.2 from2.1.3 where2.1.4 group by2.1.5 hav…...
失败的面试经历(ʘ̥∧ʘ̥)
一.面向对象的三大特性 1.封装:将对象内部的属性私有化,外部对象不能够直接访问,但是可以提供一些可以使外部对象操作内部属性的方法。 2.继承:类与类之间会有一些相似之处,但也会有一些异处,使得他们与众…...
【Jmeter】使用教程
下载及安装 参考链接: JMeter下载及安装(附插件及中文包超详细) 参考链接: 【Jmeter】win 10 / win 11:Jmeter 下载、安装、汉化、新机迁移、版本更新(Jmeter 4 以上版本均适用) 分辨率的调整 参考链接: Jmeter5.3字…...
Android 7 及以上夜神模拟器,Fiddler 抓 https 包
文章目录 问题描述解决方案环境准备操作步骤1、导出 Fiddler 证书并修改成 .pem 和 .0 文件2、修改夜神模拟器配置3、打开夜神模拟器设备的 USB 调试选项4、将0725b47c.0证书放入夜神模拟器系统证书目录5、夜神模拟器 cmd 环境配置6、给 0725b47c.0 证书赋予权限7、打开 fiddle…...
全国医院数据可视化分析系统
【大数据】全国医院数据可视化分析系统 (完整系统源码开发笔记详细部署教程)✅ 目录 一、项目简介二、项目界面展示三、项目视频展示 一、项目简介 🏥 项目名:医疗导航神器!——《基于大数据的微医挂号网医院数据可视…...
音视频入门基础:RTCP专题(1)——RTCP官方文档下载
一、引言 实时传输控制协议(Real-time Transport Control Protocol或RTP Control Protocol或简写RTCP)是实时传输协议(RTP)的一个姐妹协议。RTCP由《RFC 3550》定义(取代废弃的《RFC 1889》)。RTP使用一个…...
蓝桥杯专项复习——结构体、输入输出
目录 结构体:排序 输入输出 结构体:排序 [NOIP2007]奖学金 #include<iostream> #include<cstring> #include<algorithm>using namespace std;const int N310; int n;struct Student {int chinese,math,eng,sum;int idx; }Stu[N];//定…...
工作记录 2017-01-06
工作记录 2017-01-06 序号 工作 相关人员 1 协助BPO进行Billing的工作。 修改CSV、EDI837的导入。 修改邮件上的问题。 更新RD服务器。 郝 修改的问题: 1、 In “Full Job Summary” (patient info.), sometime, the Visit->Facility is missed, then …...
探索 Rust 高效 Web 开发:Hyperlane 框架深度解析
探索 Rust 高效 Web 开发:Hyperlane 框架深度解析 在当今的 Web 开发领域,追求高性能、轻量级的框架一直是开发者们的不懈追求。对于 Rust 语言开发者而言,Hyperlane 框架正以其独特的魅力崭露头角,为构建现代 Web 服务提供了一种…...
LLM(2):准备构建 LLM
在了解大语言模型一文中,对 LLM 做了初步介绍,本文接续前一篇文章的内容,简要介绍 LLM 的应用和构建过程。 1.2 LLM 的应用 由于大型语言模型(LLMs)在解析和理解非结构化文本数据方面具备先进能力,它们在…...
pytest+allure+jenkins
本地运行参考:pytestallure 入门-CSDN博客 jenkins运行如下: 安装插件:allure 配置allure安装目录 配置pytest、allure 环境变量 配置流水线 进行build,结果如下 ,点击allure report 查看结果...
[蓝桥杯]花束搭配【算法赛】
题目链接 题意 n朵花 每朵花有两个属性a,b 如果两朵花满足 a i a j > b i b j a_ia_j>b_ib_j aiaj>bibj 就称为完美方案 求一共有多少种完美方案 ( i , j ) 与 ( j , i ) (i,j)与(j,i) (i,j)与(j,i)视为不同组合 思路 数据范围 1 ≤ n ≤ 2 1 0 5 1\…...
大模型架构全景解析:从Transformer到未来计算范式
1. Transformer 架构 核心模型 GPT-4、BERT、T5、LLaMA、通义千问、文心ERNIE 关键技术 多头注意力:GPT-4 使用 96 头注意力位置编码创新:LLaMA 采用 RoPE(旋转位置编码),Claude 3 引入 ALiBi归一化优化࿱…...
【linux篇】--linux常见指令
文章目录 一、Linux基本概念 二、Linux入门 1.目录结构 2.Linux命令 *Linux基础命令 ls命令的选项: 3.目录切换相关命令(cd & pwd) 4.相对&绝对路径和特殊路径符 4.1相对路径 4.2绝对路径 4.3 你特殊路径符 5.创建目录命令(mkdir) 6.…...
Kubernetes的组成和架构
Kubernetes(K8s)是一个开源的容器编排平台,用于自动化部署、扩展和管理容器化应用程序。它由多个组件组成,这些组件可以分为两类:控制平面(Control Plane)组件和节点(Node࿰…...
ElementUI 表格中插入图片缩略图,鼠标悬停显示大图
如何在 ElementUI 的表格组件 Table 中插入图片缩略图,通过鼠标悬停显示大图?介绍以下2种方式: 方法1:直接在模板元素中插入 <template><el-table :data"tableData"><el-table-column label"图片…...
【实战ES】实战 Elasticsearch:快速上手与深度实践-附录-1-常用命令速查表-集群健康检查、索引生命周期管理、故障诊断命令
👉 点击关注不迷路 👉 点击关注不迷路 👉 点击关注不迷路 附录-常用命令速查表 1-Elasticsearch 运维命令速查表(集群健康检查、ILM管理、故障诊断)一、集群健康检查与监控1.1 集群健康状态核心命令1.2 节点级健康诊断…...
PlainUSR|LIA: 追求更快的卷积网络实现高效的超分辨率重建
PlainUSR|LIA: 追求更快的卷积网络实现高效的超分辨率重建 引言 在深度学习领域,图像处理始终是一个热门话题。而超分辨率重建(Super-Resolution Reconstruction, SR)作为其中一个重要的研究方向,旨在通过算法将低分辨率图像恢复…...
Linux 命令学习记录
Linux 命令详解与进阶指南 Linux 是一种广泛使用的开源操作系统,掌握 Linux 命令是开发者和系统管理员的必备技能。本文将详细介绍 Linux 的常用命令,并涵盖一些高级进阶技巧,帮助你更高效地使用 Linux。 目录 基础命令 文件与目录操作文本…...
