git命令常见用法【持续更新中……】

news2025/5/9 20:57:08

一、已有本地代码,在gitee创建了空仓库后想将代码与该仓库相连

  1. 在本地项目目录下初始化Git 

    # 1. 初始化本地仓库
    git init
    
    # 2. 添加所有文件到暂存区
    git add .
    
    # 3. 提交第一个版本
    git commit -m "Initial commit: 项目初始化"
    
  2. 将本地仓库关联到Gitee 

    根据你在 Gitee 上看到的克隆地址,选择 SSH 或 HTTPS
    # 将 origin 指向 Gitee 的仓库地址
    # SSH
    git remote add origin git@gitee.com:你的用户名/MyMusicPlayer.git 
    # HTTPS
    git remote add origin https://gitee.com/你的用户名/MyMusicPlayer.git
    

    如果是第一次使用 SSH,请先在本地生成 SSH Key 并添加到 Gitee 账户

  3. 推送到Gitee

    1. 若遇到 fatal: refusing to merge unrelated histories ,与远端无关历史,比如远端有一个空的 README 提交,本地历史不同。需要先拉取合并。
    2. 拉取远端并允许不同历史合并
      git pull origin master --allow-unrelated-histories
      
    3. 解决合并冲突,打开冲突文件,删除 <<<<<<<=======>>>>>>> 标记,合并保留你需要的内容,保存后将该文件重新 git add,git commit
    4. 合并完成后推送到 Gitee
      git push -u origin master
      
  4. 后续日常开发流程

    修改代码 → git addgit commit -m "描述"git push

二、旧仓库出问题了想换新的

删除旧远程并添加新远程

git remote remove origin
git remote add origin https://github.com/new-user/new-repo.git

如果新仓库是空的,可以直接推送现有代码

git push -u origin main

#主分支是master
git push -u origin master

 该命令中的-u与origin是指什么

origin 是什么?

origin 是 Git 默认给远程仓库起的名字(remote name),相当于是这个远程仓库的“代号”。

  • 当你克隆一个仓库时,Git 会自动把你克隆的那个远程仓库命名为 origin

  • 它其实就是一个指向远程仓库地址的简写名字。

例如:origin  https://github.com/user/project.git,表示origin 是这个远程仓库地址的代称。也可以起别的名字,例如叫 myremotegithub 等,但 origin 是默认最常用的。

-u 是什么意思?

-u--set-upstream 的缩写,用于将本地分支和远程分支建立跟踪关系

例如:git push -u origin main

这条命令的作用是:

  1. 把当前分支(比如 main)的代码推送到远程仓库 origin

  2. 并告诉 Git:以后如果你在 main 分支上执行 git pullgit push,默认就用 origin/main 作为对应的远程分支。

换句话说,有了 -u 之后,下一次你就可以直接用git push,而不用每次都写 git push origin main 这么完整。

若推送失败,提示有冲突

法一:先pull,解决掉冲突,再push

法二:若确定远程仓库可以被完全覆盖(比如你刚建仓库,没内容或无所谓),可以选择强制推送

git push -u origin master --force

三、代码修改思路错误,想回溯至远程仓库的版本

放弃本地修改(可选): 如果你希望完全放弃本地的修改,可以使用以下命令来丢弃本地所有未提交的修改

git reset --hard HEAD
# 可以不写HEAD,此时默认重置到 HEAD,即当前分支的最后一次提交
# 明确写出 HEAD(或其他引用,比如 origin/main)可以更清晰地表达你的意图,尤其在脚本或协作中更具可读性

拉取远程代码: 然后,从远程仓库拉取最新的代码

# 会将远程仓库的最新代码下载到本地,但不会自动合并到当前分支
git fetch origin

覆盖本地代码: 最后,将远程分支的代码强制覆盖当前分支的代码

git reset --hard origin/<branch-name>

ps:如果你reset以后就处于希望的历史版本,就可以不用再进行后续操作了

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Docker 渡渡鸟镜像同步站 使用教程

Docker 渡渡鸟镜像同步站 使用教程 &#x1f680; 介绍 Docker.aityp.com&#xff08;渡渡鸟镜像同步站&#xff09;是一个专注于为国内开发者提供 Docker 镜像加速和同步服务的平台。它通过同步官方镜像源&#xff08;如 Docker Hub、GCR、GHCR 等&#xff09;&#xff0c;为…

火影bug,未保证短时间数据一致性,拿这个例子讲一下Redis

本文只拿这个游戏的bug来举例Redis&#xff0c;如果有不妥的地方&#xff0c;联系我进行删除 描述&#xff1a;今天在高速上打火影&#xff08;有隧道&#xff0c;有时候会卡&#xff09;&#xff0c;发现了个bug&#xff0c;我点了两次-1000的忍玉&#xff08;大概用了1千七百…

探索元生代:ComfyUI 工作流与计算机视觉的奇妙邂逅

目录 一、引言 二、蓝耘元生代和 ComfyUI 工作流初印象 &#xff08;一&#xff09;蓝耘元生代平台简介 &#xff08;二&#xff09;ComfyUI 工作流创建是啥玩意儿 三、计算机视觉是个啥 &#xff08;一&#xff09;计算机视觉的基本概念 &#xff08;二&#xff09;计算…

Unity-Shader详解-其五

关于Unity的Shader部分的基础知识其实已经讲解得差不多了&#xff0c;今天我们来一些实例分享&#xff1a; 溶解 效果如下&#xff1a; 代码如下&#xff1a; Shader "Chapter8/chapter8_1" {Properties{// 定义属性[NoScaleOffset]_Albedo("Albedo", 2…

【Java 专题补充】流程控制语句

流程控制语句是用来控制程序中各语句执行顺序的语句&#xff0c;是程序中既基本又非常关键的部分。流程控制语句可以把单个的语句组合成有意义的、能完成一定功能的小逻辑模块。最主要的流程控制方式是结构化程序设计中规定的三种基本流程结构。 1.1 结构化程序设计的三种基本流…

【ArcGIS微课1000例】0146:将多个文件夹下的影像移动到一个目标文件夹(以Landscan数据为例)

本文讲述将多个文件夹下的影像移动到一个目标文件夹,便于投影变换、裁剪等操作。 文章目录 一、数据准备二、解压操作三、批量移动四、查看效果五、ArcGIS操作一、数据准备 全球人口数据集Landscan2000-2023如下所示,每年数据位一个压缩包: 二、解压操作 首先将其解压,方…

【redis】分片方案

Redis分片&#xff08;Sharding&#xff09;是解决单机性能瓶颈的核心技术&#xff0c;其本质是将数据分散存储到多个Redis节点&#xff08;实例&#xff09;中&#xff0c;每个实例将只是所有键的一个子集&#xff0c;通过水平扩展提升系统容量和性能。 分片的核心价值 性能提…

springboot+mysql+element-plus+vue完整实现汽车租赁系统

目录 一、项目介绍 二、项目截图 1.项目结构图 三、系统详细介绍 管理后台 1.登陆页 2.管理后台主页 3.汽车地点管理 4.汽车类别 5.汽车品牌 6.汽车信息 7.用户管理 8.举报管理 9.订单管理 10.轮播图管理 11.交互界面 12.图表管理 汽车租赁商城 1.首页 2.汽…

Linux第四节:进程控制

一、进程创建 1.1 fork函数 1. fork函数有两个返回值问题 返回的本质就是写入&#xff01;所以&#xff0c;谁先返回&#xff0c;谁就先写入id&#xff0c;因为进程具有独立性&#xff0c;会发生写时拷贝&#xff0c;父进程和子进程各自指向return语句。 2. fork返回后&#x…

Qt 编译 sqldrivers之psql

编译postgres pgsql驱动 下载驱动源码修改配置文件编译 下载驱动源码 // 源代码下载 https://download.qt.io/archive/qt/5.15/5.15.2/submodules/驱动目录:qtbase-everywhere-src-5.15.2\src\plugins\sqldrivers 修改配置文件 打开pro文件 右键点击添加库 此处的为debu…

观测云:安全、可信赖的监控观测云服务

引言 近日&#xff0c;“TikTok 遭欧盟隐私监管机构调查并处以 5.3 亿欧元”一案&#xff0c;再次引发行业内对数据合规等话题的热议。据了解&#xff0c;仅 2023 年一年就产生了超过 20 亿美元的 GDPR 罚单。这凸显了在全球化背景下&#xff0c;企业在数据隐私保护方面所面临…

【PostgreSQL数据分析实战:从数据清洗到可视化全流程】5.3 相关性分析(PEARSON/SPEARMAN相关系数)

&#x1f449; 点击关注不迷路 &#x1f449; 点击关注不迷路 &#x1f449; 点击关注不迷路 文章大纲 5.3 相关性分析&#xff08;PEARSON/SPEARMAN相关系数&#xff09;5.3.1 相关性分析理论基础5.3.1.1 相关系数定义与分类5.3.1.2 Pearson相关系数&#xff08; Pearson Corr…

python基础:序列和索引-->Python的特殊属性

一.序列和索引 1.1 用索引检索字符串中的元素 # 正向递增 shelloworld for i in range (0,len(s)):# i是索引print(i,s[i],end\t\t) print(\n--------------------------) # 反向递减 for i in range (-10,0):print(i,s[i],end\t\t)print(\n--------------------------) print(…

java反射(2)

package 反射;import java.lang.reflect.Constructor; import java.lang.reflect.Field; import java.lang.reflect.Method; import java.util.Arrays;public class demo {public static void main(String[] args) throws Exception {// 通过类的全限定名获取对应的 Class 对象…

自由学习记录(58)

Why you were able to complete the SpringBoot MyBatisPlus task smoothly: Clear logic flow: Database → Entity → Service → Controller → API → JSON response. Errors are explicit, results are verifiable — you know what’s broken and what’s fixed. Sta…

《MATLAB实战训练营:从入门到工业级应用》高阶挑战篇-《5G通信速成:MATLAB毫米波信道建模仿真指南》

《MATLAB实战训练营&#xff1a;从入门到工业级应用》高阶挑战篇-5G通信速成&#xff1a;MATLAB毫米波信道建模仿真指南 &#x1f680;&#x1f4e1; 大家好&#xff01;今天我将带大家进入5G通信的奇妙世界&#xff0c;我们一起探索5G通信中最激动人心的部分之一——毫米波信…

工程师 - 汽车分类

欧洲和中国按字母对汽车分类&#xff1a; **轴距**&#xff1a;简单来说&#xff0c;就是前轮中心点到后轮中心点之间的距离&#xff0c;也就是前轮轴和后轮轴之间的长度。根据轴距的大小&#xff0c;国际上通常把轿车分为以下几类&#xff08;德国大众汽车习惯用A\B\C\D分类&a…

57.[前端开发-前端工程化]Day04-webpack插件模式-搭建本地服务器

Webpack常见的插件和模式 1 认识插件Plugin 认识Plugin 2 CleanWebpackPlugin CleanWebpackPlugin 3 HtmlWebpackPlugin HtmlWebpackPlugin 生成index.html分析 自定义HTML模板 自定义模板数据填充 4 DefinePlugin DefinePlugin的介绍 DefinePlugin的使用 5 mode模式配置…

K8S - 金丝雀发布实战 - Argo Rollouts 流量控制解析

一、金丝雀发布概述 1.1 什么是金丝雀发布&#xff1f; 金丝雀发布&#xff08;Canary Release&#xff09;是一种渐进式部署策略&#xff0c;通过逐步将生产流量从旧版本迁移至新版本&#xff0c;结合实时指标验证&#xff0c;在最小化风险的前提下完成版本迭代。其核心逻辑…

Qt中数据结构使用自定义类————附带详细示例

文章目录 C对数据结构使用自定义类1 QMap使用自定义类1.1 使用自定义类做key1.2 使用自定义类做value 2 QSet使用自定义类 参考 C对数据结构使用自定义类 1 QMap使用自定义类 1.1 使用自定义类做key QMap<key,value>中数据存入时会对存入key值的数据进行比较&#xff…