git版本管理工具基本使用

2024-09-03 06:18

本文主要是介绍git版本管理工具基本使用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Git基本使用

软件安装

命令行软件:

Ubuntu:参考:https://git-scm.com/download/linux

sudo apt install git 

Windows:https://git-scm.com/ 下载安装即可
可通过以下命令确认是否安装成功

git --version

界面管理软件:

Ubuntu:SmartGit
Windows:git tortoise:https://tortoisegit.org/download/
clion\pycharm:内置了Git管理工具

命令操作

初始化git仓库

git init

实时查看当前仓库状态

git status

配置邮箱和用户名:(整个系统只用配置一次)

git config --global user.email "xxx@xx.com"
git config --global user.name "xxxx"

将文件变化加入到State舞台(所有文件的增删改)

git add .

将文件变化加入到State舞台(个别文件)

git add 文件名

提交Stage舞台上的所有变化(所有文件的增删改)

git commit -m "提交注释"

查看历史记录:(按q退出)

git log

文件状态说明
Untracked:未追踪状态(git add . 更新为staged)常见于新添加的文件或目录
not staged:未记录的变换(git add . 更新为staged)常见于修改、删除文件
Staged:待提交状态(需要通过 git commit -m “提交注释”)将之提交
Commited:文件已提交到版本库,会在历史记录中体现
在这里插入图片描述

提交到远程仓库

gitee, github

远程仓库初始化及push

1.创建远程仓库
2.添加远程仓库的链接,命名为origin

git remote add origin https://gitee.com/xxx/xxx

3.将当前分支和远端origin的master进行关联(只需要执行一次)

git push --set-upstream origin master

也可以使用指定的远端分支进行推送

git push -u origin main

在这里插入图片描述

获取远程仓库代码pull

1.获取已有的远程仓库代码

git clone https://gitee.com/xxx/xxx

2.如果希望获取最新的远程的代码

git pull

3.等同于

git fetch + git merge

多人协作开发

commit、push
pull、merge

冲突产生

在push之前,远程版本库中有新的提交,本地没有,执行pull,发现其中的新的提交和本地的内容(相同文件的相同行)有差异。产生冲突

冲突解决

git pull 拉取并合并
手动,使用界面工具将远程内容和本地内容进行合理的编排,执行命令继续合并过程

git add .

fix conflicts and then run “git rebase --continue”
执行推送

git push

Git分支管理

查看分支(*处于当前所在分支前面)

git branch

创建分支

git branch 新建分支名称

切换分支

git checkout 分支名称

同时创建并切换分支

git checkout -b 新建分支名称

删除分支

git branch -d 删除分支名称

分支合并

git merge
-------
git checkout 需要合并到的分支(一会会将别的分支的内容合并到此分支)
git merge 需要合并的分支(将此分支内容合并到当前分支)

Git标签

创建标签

-a 是创建一个带注释的标签,建议使用
git tag -a v1.0

查看标签

git tag

删除标签

git tag -d 标签名称

查看此版本所修改内容

git show 标签名称

Git 版本回退

查看提交日志,每一次提交都有对应的 *commit id* 和 *commit message*

git log
# 提交的信息会在一行显示
git log --pretty=oneline

根据id会退到指定的版本

git reset --hard id(根据日志,可以查看到id号)

查看命令操作的历史

git reflog

这篇关于git版本管理工具基本使用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1132260

相关文章

Java使用Javassist动态生成HelloWorld类

《Java使用Javassist动态生成HelloWorld类》Javassist是一个非常强大的字节码操作和定义库,它允许开发者在运行时创建新的类或者修改现有的类,本文将简单介绍如何使用Javass... 目录1. Javassist简介2. 环境准备3. 动态生成HelloWorld类3.1 创建CtC

使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解

《使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解》本文详细介绍了如何使用Python通过ncmdump工具批量将.ncm音频转换为.mp3的步骤,包括安装、配置ffmpeg环... 目录1. 前言2. 安装 ncmdump3. 实现 .ncm 转 .mp34. 执行过程5. 执行结

Java使用jar命令配置服务器端口的完整指南

《Java使用jar命令配置服务器端口的完整指南》本文将详细介绍如何使用java-jar命令启动应用,并重点讲解如何配置服务器端口,同时提供一个实用的Web工具来简化这一过程,希望对大家有所帮助... 目录1. Java Jar文件简介1.1 什么是Jar文件1.2 创建可执行Jar文件2. 使用java

C#使用Spire.Doc for .NET实现HTML转Word的高效方案

《C#使用Spire.Docfor.NET实现HTML转Word的高效方案》在Web开发中,HTML内容的生成与处理是高频需求,然而,当用户需要将HTML页面或动态生成的HTML字符串转换为Wor... 目录引言一、html转Word的典型场景与挑战二、用 Spire.Doc 实现 HTML 转 Word1

Java中的抽象类与abstract 关键字使用详解

《Java中的抽象类与abstract关键字使用详解》:本文主要介绍Java中的抽象类与abstract关键字使用详解,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、抽象类的概念二、使用 abstract2.1 修饰类 => 抽象类2.2 修饰方法 => 抽象方法,没有

MyBatis ParameterHandler的具体使用

《MyBatisParameterHandler的具体使用》本文主要介绍了MyBatisParameterHandler的具体使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参... 目录一、概述二、源码1 关键属性2.setParameters3.TypeHandler1.TypeHa

Spring 中的切面与事务结合使用完整示例

《Spring中的切面与事务结合使用完整示例》本文给大家介绍Spring中的切面与事务结合使用完整示例,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录 一、前置知识:Spring AOP 与 事务的关系 事务本质上就是一个“切面”二、核心组件三、完

使用docker搭建嵌入式Linux开发环境

《使用docker搭建嵌入式Linux开发环境》本文主要介绍了使用docker搭建嵌入式Linux开发环境,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录1、前言2、安装docker3、编写容器管理脚本4、创建容器1、前言在日常开发全志、rk等不同

使用Python实现Word文档的自动化对比方案

《使用Python实现Word文档的自动化对比方案》我们经常需要比较两个Word文档的版本差异,无论是合同修订、论文修改还是代码文档更新,人工比对不仅效率低下,还容易遗漏关键改动,下面通过一个实际案例... 目录引言一、使用python-docx库解析文档结构二、使用difflib进行差异比对三、高级对比方

sky-take-out项目中Redis的使用示例详解

《sky-take-out项目中Redis的使用示例详解》SpringCache是Spring的缓存抽象层,通过注解简化缓存管理,支持Redis等提供者,适用于方法结果缓存、更新和删除操作,但无法实现... 目录Spring Cache主要特性核心注解1.@Cacheable2.@CachePut3.@Ca