Git基本用法总结

news2024/9/21 18:31:51

设置全局用户名

git config --global user.name xxx #设置全局用户名

设置全局邮箱地址

git config --global user.email xxx@xxx.com     #设置全局邮箱地址

查看所有的 Git 配置,包括用户信息

git config --list  #查看所有的 Git 配置,包括用户信息
git init    #将当前目录配置成git仓库,信息记录在隐藏的.git文件夹中

git add XX  #将XX文件添加到暂存区
git add .   #将所有待加入暂存区的文件加入暂存区

git restore 命令用于恢复文件到工作区或暂存区,其 --staged 选项和不带 --staged 的版本在功能上有显著区别。

git restore --staged

  • 作用--staged 选项用于将文件从暂存区(即缓存区)移除,但不影响工作区中的文件内容。

  • 场景:当你不小心将某些文件添加到了暂存区(例如使用 git add),但是你决定不再包括这些文件在下一次提交中。使用 git restore --staged 可以将这些文件从暂存区移除,同时保留工作区中的修改。

git add a.txt  # 将 a.txt 文件添加到暂存区
git restore --staged a.txt  # 从暂存区移除 a.txt 文件,但工作区中的 a.txt 仍然存在

git restore(不带 --staged

  • 作用:不带 --staged 的 git restore 用于将文件从工作区恢复到暂存区的状态,即撤销工作区的更改,使其与暂存区中的版本一致。

  • 场景:当你在工作区中对文件进行了更改,而你希望撤销这些更改,使文件恢复到暂存区中的状态(即最后一次添加或提交的状态)。这将覆盖工作区中的修改,但不会影响暂存区中的文件。

git add a.txt  # 将 a.txt 文件添加到暂存区
echo "some changes" >> a.txt  # 对 a.txt 文件进行修改
git restore a.txt  # 将 a.txt 文件恢复到暂存区中的版本,即撤销对 a.txt 的修改

将暂存区的内容提交到当前分支

git commit -m "给自己看的备注信息"

查看仓库状态

git status        #查看仓库状态

查看XX文件相对于暂存区修改了哪些内容

git diff XX   #查看XX文件相对于暂存区修改了哪些内容

查看当前分支的所有版本

git log      #查看当前分支的所有版本

查看HEAD指针的移动历史(包括被回滚的版本)

git reflog       #查看HEAD指针的移动历史(包括被回滚的版本)

将代码库回滚到上一个版本

git reset --hard HEAD^     #将代码库回滚到上一个版本

回滚

git reset --hard HEAD^^      #往上回滚两次,以此类推
git reset --hard HEAD~100    #往上回滚100个版本

回滚到某一特定版本

git reset --hard 版本号   #回滚到某一特定版本

生成密钥

ssh-keygen -t rsa       #生成后一路回车

获取密钥

cat ~/.ssh/id_rsa.pub   #公钥

验证是否认证成功(用Gitee)

ssh -T git@gitee.com

在本地告诉终端,远程仓库的地址(这里是将本地仓库与云端的新建的一个仓库连接,情景是:我先在本地开发一些项目,但是没有上传,然后我在Gitee中创建一个仓库叫git_test.git。我现在想要将本地的上传到云端,首先要建立连接,然后再上传)

git remote add origin git@gitee.com:someone/git_test.git #最后一个是地址,起一个名字叫origin

查看远程仓库

git remote

将本地文件夹推送到远程仓库

git push -u origin master

git push -u (第一次需要-u以后不需要):将当前分支推送到远程仓库

git push -u (第一次需要-u以后不需要)        #将当前分支推送到远程仓库

将云端的项目克隆到本地

git clone git@git.acwing.com:xxx/XXX.git

创建并切换到branch_name这个分支

git checkout -b branch_name   #创建并切换到branch_name这个分支

查看所有分支和当前所处分支

git branch        #查看所有分支和当前所处分支

切换到branch_name这个分支

git checkout branch_name      #切换到branch_name这个分支

将分支branch_name合并到当前分支上(注意,一般先切换到主分支,然后合并其他分支)

git merge branch_name     #将分支branch_name合并到当前分支上

删除分支(注意:要删除这个分支,首先要进其他分支。)

git branch -d branch_name     #删除本地仓库的branch_name分支

创建新分支

git branch branch_name    #创建新分支

设置本地的branch_name分支对应远程仓库的branch_name分支(注意,这里可以简单的git push 然后如果远程仓库没有这个分支,终端会报错,然后会打印一个命令,直接复制这个命令然后在终端执行就可以了)(这个是本地有这个分支,但是云端没有,需要将本地的分支上传到云端)

git push --set-upstream origin branch_name  # 设置本地的branch_name分支对应远程仓库的branch_name分支

删除远程仓库的branch_name分支

git push -d origin branch_name         #删除远程仓库的branch_name分支

将远程的branch_name1分支与本地的branch_name2分支对应(绑定在一起)(这个是云端已经有分支了,但是本地没有对应的,需要在本地先建立一个这个分支,然后将这个分支与云端的分支对应)

git branch --set-upstream-to=origin/branch_name1 branch_name2   #将远程的branch_name1分支与本地的branch_name2分支对应

#然后拉下来,并且*******合并*****
git pull

将云端的分支拉下来也可以不用“先同步两个分支”,可以在云端的一个分支和本地一个直接合并(这里是,云端有一个本地没有的分支,branch_name 然后将云端的这个分支合并到本地当前分支)

git pull origin branch_name   #将远程仓库的branch_name分支与本地仓库的当前分支合并

`git clone` 和 `git pull` 是 Git 中两个不同的命令,它们的功能和用途如下:

1. `git clone`

- **功能**:将远程仓库的所有内容(包括文件、历史记录、分支等)复制到本地计算机。
- **使用场景**:通常在你第一次获取一个远程仓库时使用
 

  git clone https://gitee.com/username/repo.git

2. `git pull`

- **功能**:从远程仓库拉取最新的更改并合并到当前本地分支。相当于 `git fetch` 和 `git merge` 的组合。
- **使用场景**:在你已经有了本地仓库,并想更新本地分支以获取最新的更改时使用。

  git pull origin your-branch-name

总结

- **`git clone`**:用于首次获取整个仓库。
- **`git pull`**:用于更新已存在的本地仓库。

这两个命令在工作流程中起到不同的作用。希望这个解释对你有帮助!如果还有其他问题,随时问我!

注意:

当你使用 git clone 命令时,Git 会自动为你创建一个与远程仓库的连接,包括设置 origin 作为默认的远程仓库。不需要使用“git remote add origin git@git.acwing.com:xxx/XXX.git:将本地仓库关联到远程仓库”。

具体说明

  • git clone:这个命令会将远程仓库的内容克隆到你的本地计算机,并自动设置好远程仓库的地址(例如 origin),你不需要手动执行 git remote add origin ...

例子

当你执行以下命令:

git clone git@git.acwing.com:xxx/XXX.git

Git 会执行以下操作:

  1. 克隆远程仓库的所有内容。
  2. 创建一个名为 origin 的远程连接,指向你克隆的仓库。
  3. 默认会将当前分支设置为跟踪远程的主分支(通常是 main 或 master)。

总结

因此,使用 git clone 后,你就不需要再手动添加远程仓库的关联了。如果你想查看当前的远程仓库设置,可以使用:

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

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

相关文章

Python爬虫使用实例-umei

优美图库 www.umei.cc BV1Ag41137re 1/获取资源 查看网站资源结构 多页,每个item只有一张图 多页,每个item都是一个图集 最大页码 内外层图集均有若干page。 通过尾页按钮确定pageNum: 2/发送请求 response requests.get(urlurl, header…

快速将Mongo Compass的shell语句转成java代码

步骤一、从MongoCompass中获取java代码 将java代码复制出来&#xff0c;从MongoCompass中复制的java代码基本格式如下&#xff1a;&#xff08;是Bson原生格式&#xff09; List<Document> list Arrays.asList(new Document("$match",new Document("name…

探索视频美颜SDK与直播美颜工具的开发实践方案

直播平台的不断发展&#xff0c;让开发出性能优异、效果自然的美颜技术&#xff0c;成为了技术团队必须面对的重要挑战。本篇文章&#xff0c;小编将深入讲解视频美颜SDK与直播美颜工具的开发实践方案。 一、视频美颜SDK的核心功能 视频美颜SDK是视频处理中的核心组件&#xf…

Cocos Creator3.x设置动态加载背景图并且循环移动

效果图 项目结构 项目层级结构&#xff1a; 预制&#xff1a; 代码 import { _decorator, CCFloat, Component, Node, Sprite, instantiate, Prefab, assert } from cc; const { ccclass, property } _decorator;/*** 背景脚本*/ ccclass(Background) export class Backg…

2024年华为杯研赛(D题)数学建模竞赛解题思路|完整代码论文集合

我是Tina表姐&#xff0c;毕业于中国人民大学&#xff0c;对数学建模的热爱让我在这一领域深耕多年。我的建模思路已经帮助了百余位学习者和参赛者在数学建模的道路上取得了显著的进步和成就。现在&#xff0c;我将这份宝贵的经验和知识凝练成一份全面的解题思路与代码论文集合…

反激电路中TL431光耦反馈参数的计算,环路设计思路

反馈的过程 当副边的输出电压升高时&#xff0c;TL431参考端电压&#xff08;R端&#xff09;电压也会升高&#xff0c;使得TL431的导通量增加&#xff0c;同时光耦内部的发光二极管流过的电流也会增大&#xff0c;进而使得光耦三极管导通量增加&#xff0c;相连的电源IC电压反…

《粮油与饲料科技》是什么级别的期刊?是正规期刊吗?能评职称吗?

问题解答 问&#xff1a;《粮油与饲料科技》是不是核心期刊&#xff1f; 答&#xff1a;不是&#xff0c;是知网收录的第一批认定 学术期刊。 问&#xff1a;《粮油与饲料科技》级别&#xff1f; 答&#xff1a;省级。主管单位&#xff1a;中文天地出版传媒集团股份有限公司…

缺陷及缺陷管理(复习)

​ 大家好&#xff0c;我是程序员小羊&#xff01; 前言&#xff1a; 今日目标 能够说出缺陷的判定标准 能够说出描述缺陷的6大核心内容 能够描述缺陷状态、严重程度、优先级的作用 能够按照提供的缺陷模版完成一个缺陷的提交 能够说出缺陷的跟踪流程 能够在禅道中提交测…

黑神话:悟空配置推荐,升级显卡还是ToDesk云电脑

虽然距离《黑神话&#xff1a;悟空》上线已有一个月的时间&#xff0c;但该游戏在国内外市场仍然火热&#xff0c;想要玩好、玩顺它着实是需要花费一些心力的。除了操作上的经验、技巧&#xff0c;用高配置电脑设备来实现无疑是最为关键的要素之一。那么如若现有机型性能不足&a…

2024年华为杯数学建模研赛(C题) 建模解析| 磁芯损耗建模 | 小鹿学长带队指引全代码文章与思路

我是鹿鹿学长&#xff0c;就读于上海交通大学&#xff0c;截至目前已经帮2000人完成了建模与思路的构建的处理了&#xff5e; 本篇文章是鹿鹿学长经过深度思考&#xff0c;独辟蹊径&#xff0c;实现综合建模。独创复杂系统视角&#xff0c;帮助你解决研赛的难关呀。 完整内容可…

(学习总结18)C++多态

C多态 一、多态的概念二、多态的定义及实现多态的构成条件1. 实现多态的两个必须条件&#xff1a;2. 虚函数3. 虚函数的重写/覆盖4. 多态场景的一个选择题5. 虚函数重写的一些其他问题协变析构函数的重写 6. override 和 final 关键字7. 重载/重写/隐藏的对比 三、纯虚函数和抽…

【堆栈操作基本规则】假设SS的初值为2000H,SP初值为0200H,在执行了5次入栈操作和2次出栈操作后SP的内容为多少?写出计算过程。

欢迎来到我的技术博客&#xff01; &#x1f389; 这里不仅有满满的编程干货和学习资源&#xff0c;我的某站账号也为你准备了更多实用的技术视频和知识分享。 &#x1f449; 点击关注我的小破站账号&#xff0c;获取更多编程技巧和学习资源&#xff01; 小破站主页 我们来逐…

新手入门:小程序架构快速上手

目录 新建项目和配置 项目基本结构 新建小程序页面 修改项目首页 全局配置 窗口 tabBar 页面配置 小程序基本语法 wxml 数据绑定 条件渲染 列表渲染 wxss wxss 对比 css rpx import 全局样式和局部样式 js wxs 数据请求 get和post请求 小程序和跨域 小程…

C++进阶 set和map讲解

set 和 map set 和 multiset set set 类的介绍 set 是基于红黑树实现的有序容器。它的插入、删除、查找操作的时间复杂度均为 O(log n)。遍历时&#xff0c;set 的迭代器按照中序遍历&#xff0c;因此它总是以升序排列元素。 set 的声明如下&#xff0c;T 表示 set 的关键字类…

The First项目报告:变革全链身份,Layer3的未来价值解读

2024年7月5日&#xff0c;代币分发协议 Layer3 基金会公布代币 L3 经济模型&#xff0c;以任务平台为市场切入点的 Layer3 聚合了市场上花样繁多的项目&#xff0c;帮助用户实现通过一个平台交互全链项目的操作。乘着牛市的浪潮&#xff0c;各链生态重新火热&#xff0c;Layer3…

微服务_入门1

文章目录 一、 认识微服务二、 微服务演变2.1、 单体架构2.2、 分布式架构2.3、 微服务2.4、 微服务方案对比 三、 注册中心3.1、 Eureka3.2、 Nacos3.2.1、服务分级存储模型3.2.2、权重配置3.2.3、环境隔离 一、 认识微服务 二、 微服务演变 随着互联网行业的发展&#xff0c;…

Java项目实战II基于Java+Spring Boot+MySQL的洗衣店订单管理系统(开发文档+源码+数据库)

目录 一、前言 二、技术介绍 三、系统实现 四、论文参考 五、核心代码 六、源码获取 全栈码农以及毕业设计实战开发&#xff0c;CSDN平台Java领域新星创作者 一、前言 随着生活节奏的加快&#xff0c;现代人对便捷、高效服务的需求日益增长&#xff0c;洗衣店作为日常生…

[Linux] Linux操作系统 进程的状态

标题&#xff1a;[Linux] Linux操作系统 进程的状态 个人主页&#xff1a;水墨不写bug &#xff08;图片来源于网络&#xff09; 目录 一、前置概念的理解 1.并行和并发 2.时间片 3.进程间具有独立性 4.等待的本质 正文开始&#xff1a; 在校的时候&#xff0c;你一定学过《…

【自然语言处理】补充:词项权重计算及向量空间模型

【自然语言处理】补充:词项权重计算及向量空间模型 文章目录 【自然语言处理】补充:词项权重计算及向量空间模型1. 排序式检索2. 词项频率3. tf-idf权重计算4. 向量空间模型1. 排序式检索 布尔检索的不足:结果过少或者过多 布尔查询常常会是过少(=0)或者过多(>1000)在…

Python “函数” ——Python面试100道实战题目练习,巩固知识、检查技术、成功就业

本文主要是作为Python中函数的一些题目&#xff0c;方便学习完Python的函数之后进行一些知识检验&#xff0c;感兴趣的小伙伴可以试一试&#xff0c;含选择题、判断题、实战题、填空题&#xff0c;答案在第五章。 在做题之前可以先学习或者温习一下Python的函数&#xff0c;推荐…