Git使用总结(git使用,git实操,git命令和常用指令)

news2025/1/15 23:26:26

简介:Git是一款代码版本管理工具,可以记录每次提交的代码,防止代码丢失,可实现版本迭代,解决代码冲突,常用的远程Git仓库:Gitee(国内)、GitHub(国外,开源之家)、GitLab(企业级)。



一. Git安装使用

下载地址:

GIt官网icon-default.png?t=N7T8https://www.git-scm.com/Git版本安装验证:

git --version / git -v
//显示
git version 2.37.3.windows.1



二. git拉取代码,git克隆仓库的两种情况

1. 仓库有代码时

git clone 项目地址/https


2. 仓库没有代码时,连readme都没有(按操作步骤,上传文件)
 

git init  生成.git目录

git remote add origin  远程仓库地址 #本地仓库关联到远程仓库

git add .  添加到本地

git commit -m '备注'  提交备注(就是你干了什么,写上)

git push --set-upstream origin 分支名

刷新远程仓库查看

git remote remove origin  移除本地仓库关联的远程仓库,可重新绑定


三. git克隆仓库的两种方法

1. HTTPS(超文本传输协议),首次使用,初始化个人信息(填写个人用户信息)

git config --global user.name '用户名'

git config --global user.email '邮箱'

克隆命令:git clone 仓库地址/https

2. SSH(一次声明永久使用)

生成密钥:ssh-keygen -t rsa -C "邮箱"

复制公钥:cat ~/.ssh/id_rsa.pub

配置到远程仓库,举例gitee:设置 ->SSH公钥 -> 添加公钥

克隆:git clone 仓库地址/SSH


四. git增删改

1. git add .  添加到暂存区(开发区域 -> 暂存区);

2. git commit -m '备注'提交到本地区域 (暂存区 ->本地区域);

3. git pull  远程仓库的代码拉到本地"合并";

4. git push  本地代码提交到远程仓库(本地区域 -> 远程区域);

5. git status  查看文件状态;

6. git fetch    
   远程仓库的数据拉到本地"不合并";
  (此命令并不强迫让远端的变更合并到你的仓库,会对本地内容与fetch下载的内容进行隔离;)


五. git日志回滚

查看日志(提交的历史记录):

1.git log(详细但条数少,回车查看更多)

2.git log --pretty=oneline(相对没有1详细,格式化后的,回车查看更多)

代码回滚(回到你提交的那个版本):
git reset --hard HEAD^          回退到上个版本
git reset --hard HEAD~3         回退到前3次提交之前,以此类推,回退到n次提交之前

回退到指定版本(很长,唯一标识前7个字母即可,commit_id就是那个标识字符)
git reset --hard commit_id      


六. git分支

查看分支:
git branch 查看自己创建的(克隆的仓库就算创建的第一个分支)
git branch -r  查看从远程缓存的分支
git branch -a  查看1+2

创建分支:
git branch 分支名 (基于当前分支)
git branch 新分支名 旧分支名 (基于指定分支)

切换分支:
git checkout 分支名
创建并切换分支:
git checkout -b 分支名 (基于当前分支)
git checkout -b 新分支名 旧分支名(基于指定分支)

删除分支:
git branch -d 分支名 (删除分支)
git branch -D 分支名 (强制删除分支)


七. git代码冲突

问题:git push 时报错,原文件冲突

解决:

1. git pull 从远程仓库拿到最新的代码(先添加到本地git add . ,
   然后再添加备注git commit -m '' ,
   然后先拉取.git pull,解决完冲突后,再推送git push)

2. git status 查看状态,根据提示去修改冲突文件

3. 重新git add . / git commit -m '' / git push


八. git实操和其它

git stash                  //存到临时区
git stash list             //查看临时区列表 
git stash pop              //弹出临时区

git tag  <tagName>               //创建本地tag;
git push origin  <tagName>       //推送到远程仓库;


//若存在很多未推送的本地标签,一次性全部推送;
git push origin --tags     
  
git show <tagName>                    //查看本地某个 tag 的详细信息;
git tag 或者 git tag -l               //查看本地所有 tag;
git ls-remote --tags origin           //查看远程所有 tag;
git tag -d <tagName>                  //本地 tag 的删除;
git push origin :refs/tags/<tagName>  //远程 tag 的删除;
tag是git版本库的一个标记,指向某个commit的指针,
创建 tag 是基于本地分支的 commit,而且与分支的推送是两回事,
就是说分支已经推送到远程了,但是你的 tag 并没有,
如果把 tag 推送到远程分支上,需要另外执行 tag 的推送命令;

//远程仓库的数据拉到本地"合并",合并意味着可能存在冲突或者修改,
//因此每次合并后必定git status查看冲突解冲突(git pull = git fetch + git merge 分支名)
git pull  
//远程仓库的数据拉到本地"不合并"
git fetchb      
//恢复之前最新/h恢复已删除(撤消工作区的修改返回到最近一次add(缓存区)的
//版本或者最近一次commit(当前版本库)的版本)            
git restore 文件名  

git log                           //查看提交历史
git branch                        //检测分支
git branch dev                    //创建dev分支
git checkout dev                  //切换到dev分支
git checkout -b dev               //创建并使用dev分支 
git checkout master               //切回到主分支
git merge dev                     //把dev合并到master主分支
git branch -v                     //查看分支
git merge 分支名                  //指定分支合并到当前分支

git clone https://gitee.com/fenghuanb2/a2105.git  //克隆远层仓库文件到本地文件夹

//把本地仓库(文件夹)推到远程仓库(gitee),origin(名字随便起的);
git remote add origin HTTPS  

git push origin master:master  //把本地仓库主分支推到远程仓库主分支;

//把dev分支添加到名字为origin的远程仓库(或者是git push HTTPS,少用);
git push origin dev:dev  

git remote -v  //查看仓库数量、状态;

git push --set-upstream origin dev  //创立本地和远程对应关系;

Everything up-to-date  //所有都是最新


⭐隐藏文件和相关问题

一. 隐藏文件

1. .git(非常重要)> config文件存放了push提交的仓库地址

2. .gitignore是git忽略上传的文件


二. 相关问题

1. 切换分支代码丢失?

解决:

第一种:切换分支前,git add .  &&  git commmit -m '备注'

第二种:存到临时区,git add .  &&  git stash  使用的时候再弹出来 git stash pop(弹到当前分支)

2. 大家普遍克隆的是dev  因为它是默认分支,然后老大说一句话  让你拉去login分支代码开发?基于码云的login分支开发代码(即基于远程创建分支)?

解决:

git branch login  错误的  这不是基于码云 git branch 新分支名  指定分支名

git checkout -b login  错误的  这不是基于码云 git checkout -b 新分支名  指定分支名


三. 注意事项

1. 第一次创建分支push到远程仓库时间较长

git push --set-upstream origin 分支名

2. 基于旧分支创建的新分支,新分支有代码(传值)

新旧分支互不影响

3. 切换分支必须git add. && git commit或者git add . &&  git stash(否则代码丢失)


四. Git的相关命令都是通用的,Gitee(国内)、GitHub(国外)、GitLab(企业级)

创作不易,感觉有用,就一键三连,感谢(●'◡'●)

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

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

相关文章

全球AI新闻速递6.7

1.智谱 AI 宣布全模型矩阵降价&#xff0c;开源 GLM-4-9B 系列模型。 2.复旦大学计划在2024-2025新学年推出至少100门。 3.思科&#xff1a;启动 10 亿美元 AI 基金&#xff0c;投资AI初创公司。 4.OpenAI和谷歌DeepMind员工联名发声&#xff1a;高级AI风险巨大&#xff0c;…

Flutter开发效率提升1000%,Flutter Quick教程之对Widget进行删除,剪切,粘贴

一&#xff0c;删除操作 1&#xff0c;首先我们选中要删除的Widget。 2&#xff0c;在左边的侧边栏&#xff0c;点击删除按钮&#xff0c;即可完成对组件的删除操作。 二&#xff0c;剪切。剪切是相同的道理&#xff0c;都是先选中&#xff0c;再点击对应的按钮。 1&#xff…

UE4_环境_材质函数

学习笔记&#xff0c;不喜勿喷&#xff0c;欢迎指正&#xff0c;侵权立删&#xff01; 1、建立材质函数Distance_Fun&#xff0c;勾选公开到库。 2、添加函数输入节点FunctionInput&#xff0c; 这个输入我们想作为混合材质属性BlendMaterialAttributes的alpha输入节点&#x…

钓鱼攻击的隐性经济

近年来&#xff0c;网络钓鱼形势发生了重大变化&#xff0c;涵盖了各种类型的攻击。许多公司已经开发了分类法来对不同的网络钓鱼攻击进行分类&#xff0c;类似于BlueVoyant 提出的分类法。该分类法概述了几种类型的网络钓鱼攻击&#xff0c;例如&#xff1a; 1. 电子邮件钓鱼…

一举高“粽“,考生请注意!AI监考来了...

&#x1f4e2;&#x1f4e2;&#x1f4e2;&#x1f4e3;&#x1f4e3;&#x1f4e3; 作者&#xff1a;IT邦德 中国DBA联盟(ACDU)成员&#xff0c;10余年DBA工作经验&#xff0c; Oracle、PostgreSQL ACE CSDN博客专家及B站知名UP主&#xff0c;全网粉丝10万 擅长主流Oracle、My…

什么是Swagger UI ,swagger ui 的authorization怎么获取?

什么是Swagger UI Swagger UI 是一个用于可视化和交互式地展示API文档的工具。它是Swagger&#xff08;现称为OpenAPI&#xff09;生态系统的一部分&#xff0c;旨在帮助开发者和API用户更好地理解、测试和调试API。 主要功能和作用 1. API文档自动生成&#xff1a; Swagge…

用户管理的小demo--过滤器filter

1、创建 CharEncodingFilter.java package com.by.filter; import javax.servlet.*; import java.io.IOException; public class CharEncodingFilter implements Filter {Overridepublic void init(FilterConfig filterConfig) throws ServletException {}Overridepublic void …

一个AI板卡电脑--香橙派 AIpro

本文算是一个开箱测评&#xff0c;主要评估它和一个电脑的距离。 香橙派官网&#xff1a;香橙派(Orange Pi)-Orange Pi官网-香橙派开发板,开源硬件,开源软件,开源芯片,电脑键盘香橙派&#xff08;Orange Pi&#xff09;是深圳市迅龙软件有限公司旗下开源产品品牌;香橙派&#x…

LabVIEW飞机发动机测试与故障诊断系统

LabVIEW飞机发动机测试与故障诊断系统 基于LabVIEW开发了一个飞机发动机测试与故障诊断系统&#xff0c;能够实时监测发动机的运行参数&#xff0c;进行数据采集与分析&#xff0c;并提供故障诊断功能。系统采用高精度传感器和数据采集硬件&#xff0c;适用于发动机的性能测试、…

Flink Sql:四种Join方式详解(基于flink1.15官方文档)

JOINs flink sql主要有四种连接方式&#xff0c;分别是Regular Joins、Interval Joins、Temporal Joins、lookup join 1、Regular Joins&#xff08;常规连接 &#xff09; 这种连接方式和hive sql中的join是一样的&#xff0c;包括inner join&#xff0c;left join&#xff…

240508Scala笔记

240508Scala笔记 Scala概述: SCala是Java的拓展,在Java的基础上又拓展了一些语法,例如: 输出Hello World println("HelloWorld")System.out.println("Hello Scala from Java") 上面两段代码都可以输出内容. package chapter01 ​ /*object: 关键字,声明…

python_将二维列表转换成HTML格式_邮件相关

python_将二维列表转换成HTML_邮件相关 data[["理想","2"],["理想2","3"]]def list_to_html_table(data):"""将二维列表转换为HTML表格格式的字符串。参数:data -- 二维列表&#xff0c;表示表格的数据。返回:一个字符…

手机相册的排列方式探讨

不论你是不是程序员&#xff0c;你一定留意过一个问题&#xff1a;相册 App 基本都将图片裁剪成了居中的 1:1 正方形。那么手机相册 App&#xff0c;为什么要将图片切割成 1:1 正方形&#xff0c;然后以网格排列&#xff1f;是行业标准吗&#xff1f; 自适应图片宽度的图库&a…

在不受支持的 Mac 上安装 macOS Sonoma (OpenCore Legacy Patcher v1.5.0)

在不受支持的 Mac 上安装 macOS Sonoma (OpenCore Legacy Patcher v1.5.0) Install macOS on unsupported Macs 请访问原文链接&#xff1a;https://sysin.org/blog/install-macos-on-unsupported-mac/&#xff0c;查看最新版。原创作品&#xff0c;转载请保留出处。 作者主…

[AIGC] 详解Mockito - 简单易学的Java单元测试框架

在Java的世界中, 单元测试是一项非常重要的任务. Mockito作为一个强大灵活的mock框架&#xff0c;可以帮助我们有效的编写和管理我们的单元测试. 了解并掌握Mockito的使用对于提高我们的开发效率和保证我们的软件质量有着巨大的帮助. 文章目录 什么是Mockito?Mockito的核心API…

【2024】Java,jdk环境变量配置(Windows)

只写了需要配置的环境变量 注&#xff1a;从JDK1.5开始&#xff0c;配置Java环境变量时&#xff0c;不再需要配置CLASSPATH&#xff0c;只需要配置JAVA_HOME和Path 操作流程 jdk8&#xff08;或者你有自定义的jre文件夹&#xff09;执行步骤1、2、4jdk8以上&#xff08;17或2…

内网快速传输工具

常见的有LANDrop&#xff0c;支持多种设备&#xff0c;如电脑、pad、手机等等之间互传。但本文介绍的这款是很小的电脑间互传工具。 特点是非常的快速&#xff0c;文件很小&#xff0c;不用安装解压就可用。

太阳能航空障碍灯在航空安全发挥什么作用_鼎跃安全

随着我国经济的快速发展&#xff0c;空域已经成为经济发展的重要领域。航空运输、空中旅游、无人机物流、飞行汽车等经济活动为空域经济发展提供了巨大潜力。然而&#xff0c;空域安全作为空域经济发展的关键因素&#xff0c;受到了广泛关注。 随着空域经济活动的多样化和密集…

【阿里云】在云服务器ECS 安装MySQL、本地远程连接或宝塔连接(手动部署)

目录 一、安装MySQL 二、配置MySQL 三、远程访问MySQL数据库 四、Navicat本地连接远程MySQL 五、宝塔连接MySQL 如果你是使用宝塔安装的MySQL请绕过&#xff0c;以下是通过命令行模式&#xff08;手动部署&#xff09;进行安装、配置及运行。 安装&#xff1a;MySQL8.0 …

LabVIEW软件开发人员的核心能力是什么

LabVIEW软件开发人员的核心能力包括以下几个方面&#xff1a; 1. LabVIEW编程技能 熟练掌握LabVIEW编程语言&#xff1a;包括虚拟仪器&#xff08;VI&#xff09;的创建、数据流编程、图形化编程技巧等。 模块化编程&#xff1a;能够设计和实现模块化的代码结构&#xff0c;便…