Git【版本控制命令】

news2025/1/12 6:58:25

02 【本地库操作】

1.git的结构

image-20221006131836575

image-20220827212525927

2.Git 远程库——代码托管中心

2.1 git工作流程

代码托管中心用于维护 Git 的远程库。包括在局域网环境下搭建的 GitLab 服务器,以及在外网环境下的 GitHub 和 Gitee (码云)。

一般工作流程如下:

1.从远程仓库中克隆 Git 资源作为本地仓库。

2.从本地仓库中checkout代码然后进行代码修改

3.在提交前先将代码提交到暂存区。

4.提交修改。提交到本地仓库。本地仓库中保存修改的各个历史版本。

5.在修改完成后,需要和团队成员共享代码时,可以将代码push到远程仓库。

团队内部协作

image-20220827212710234

跨团队协作

image-20220827212722660

2.2 Github:开源社区

Github线上仓库结构介绍

image-20221006132339079

Github Issues

作用:发现代码BUG,但是目前没有成型代码,需要讨论时用;或者使用开源项目出现问题时使用

fork与git clone的区别

1.区别

git clone 是在自己电脑直接敲命令,结果是将github仓库中的项目克隆到自己本地电脑中了(就是下载过来)

fork是直接访问github网站,在项目页面中点击fork,然后自己github项目中就会多出一个复制的项目

2.用法

如果我们想要修改他人github项目的话,我们直接git clone代码到本地是不能push的,所以我们使用fork,先把代码复制到自己的github仓库,然后git clone到本地修改,然后在提交push(这里的push是push到自己github仓库了,我们自己的github仓库中的代码是fork源的一个分支),这时候我们想要把修改的代码提交给他人的话,就可以在自己github上pull requests,等其他人看到后就可以把代码做一个合并

3.初始化配置

以本地计算机的G:\Desktop\git的工作目录,在其中新建一个项目文件夹git_demo后打开。

执行git init对git存储库初始化

查看.git文件夹中的信息

文件./.git/config用于记录该本地库的配置信息。

注意:.git 目录中存放的是本地库相关的子目录和文件,不要删除,也不要胡 乱修改。

3.1 设置签名

签名由user. name (用户名)和user. email (Email地址)组成,用于对不同开发者的身份作区分,包括项目/仓库级别、系统用户级别。

这里设置的签名和登录远程库(代码托管中心)的账号、密码没有任何关系。
项目/仓库级别与系统用户级别必须有一个设置生效。

3.1.1 项目/仓库级别

具有更高的优先级签名;
各个本地库的签名信息相互独立,互不干扰。

git config user.name "dselegent"
git config user.email dselegent@qq.com

配置文件的修改保存在:<Project>/.git/config文件中。

image-20220827214121295

3.1.2 系统用户级别

若未设置项目/仓库级别的签名时,使用用户级别的签名。

git config --global user.name "dselegent"
git config --global user.email dselegent@qq.com

配置文件的修改保存在:~/.gitconfig文件中。

image-20220827214440210

级别优先级

  • 就近原则:项目级别优先于系统用户级别,二者都有时采用项目级别 的签名
  • 如果只有系统用户级别的签名,就以系统用户级别的签名为准
  • 二者都没有不允许

3.2 配置编辑器

使用命令git config [--global | --system] core.editor [...]为 Git 的配置编辑器。

3.3 配置信息

使用命令git config --list查看 Git 的配置信息。

image-20220827214826684

4.版本控制

4.1 在项目中新建文件

G:\Desktop\git中新建文件test1.txt后打开。

hello git!
4.1.1 查看状态

使用git status查看工作区、暂存区状态

image-20211126104411928

对于master分支,本地库暂未有任何被提交的内容、暂存区亦未有任何可提交的内容(可用git add命令追踪新建的文件), 存在未追踪的文件test1.txt (可用git add <file>... 命令将文件载入暂存
区以待提交)。

4.1.2 添加到暂存区

git add test1命令将文件test1.txt添加到暂存区。

警告:此时根据转换文本文件行尾换行的配置,默认按照Windows风格检出后用Unix的风格替换提交(将LF转换为CRLF) ,本地工作目录不受这一替换的影响。

对于master分支,本地库暂未有任何被提交的内容、暂存区有以下新文件的改变可被提交:test1.txt (可用git rm --cached <fi1e>... 命令将文件撤出暂存区)。

从暂存区撤出文件的命令不会影响工作区的文件。

touch 文件名 创建文件

git add 文件名 将文件添加到暂存区

git add 文件名1 文件名2 文件名3 将多个文件添加到暂存区

git add . 添加当前目录下的文件到缓存区,注意有空格在.前面

4.1.3 提交到本地库

git commit test1 -m 'first commit'命令将文件test1.txt提交到本地库。

master分支上创建了一个根提交(ID号:da56888) 。注释内容为: first commit 。这次提交修改/新建了1个文件,插入了1行内容。

对于master分支,暂存区暂未有任何可提交的内容,工作目录的文件系统树完全一致。

4.2 修改文件内容

对文件test.txt做出 1 处修改后保存:

hello git!
second
4.2.1 查看状态

对于master分支,存在未暂存的修改: test1.txt (可用git add <file>... 命令将文件更新到
暂存区以待提交或用git restore <file>... 命令丢弃工作目录的更改)。暂存区没有可提交的修改(可用git add 命令将修改添加到暂存区或用git commit -a 将修改暂存后立即提交)。

4.2.2 添加到暂存区

image-20220827215839107

4.2.3 提交修改到本地库

使用git commit text -m "My second commit”命令提交修改到本地库,而不必单独用编辑器注释修改。

image-20220827220146316

4.3 查看提交的版本记录

image-20220827220308190

每一个提交记录(commit)都有一个hash值作为提交记录的键,与提交人、提交时间以及提交注释对应。在当前的版本中,有(HEAD -> master)的标记,即用HEAD指针指向当前版本。

版本间的切换通过移动HEAD指针完成。

若日志信息太多,可用空格键向下翻页、b键向上翻页、q键退出。

  • 可用git 1og --pretty=oneline 命令以每个提交历史仅占1行的方式显示日志;

  • 可用git 1og --oneline命令显示更简略的日志信息,此时只截取显示40位hash值的前7位;

  • 可用git reflog 命令显示带HEAD指针移动次数的简略信息。.

git reflog命令可显示HEAD指针前后的全部提交日志;其他日志查看命令只显示从当前版本往后的提交日志。

DS@DS MINGW64 /g/Desktop/git/git_demo (master)
$ git log --pretty=oneline
a087691b1b36033551860de2923512caaa593b06 (HEAD -> master) My second commit
da568881807198113fa60debe615bcd0cc7834e1 first commit

DS@DS MINGW64 /g/Desktop/git/git_demo (master)
$ git log --oneline
a087691 (HEAD -> master) My second commit
da56888 first commit

DS@DS MINGW64 /g/Desktop/git/git_demo (master)
$ git reflog
a087691 (HEAD -> master) HEAD@{0}: commit: My second commit
da56888 HEAD@{1}: commit (initial): first commit

4.4 版本的切换

版本前进后退的本质是HEAD指针的位置的移动。

4.4.1 版本的直达

使用git reset --hard <hash_len_7>命令。

4.4.2 版本后退

方法一

使用git reset --hard HEAD[^...]执行版本的后退(每个^符号后退 1 版,不加^符号则恢复成当前指针所指位置的状态)。

git reset --hard HEAD^ 表示回退一个版本

git reset --hard HEAD^^ 表示回退两个版本

git reset --hard HEAD^^^ 表示回退三个版本

git reset --hard HEAD^^^^ 表示回退四个版本

image-20220827221518210

方法二

使用git reset --hard HEAD~[NumberOfSteps]执行版本的前进(~符号后的数字注明了连续后退的步数)。

git reset --hard~3 表示回退三个版本

image-20220827222013161

做了第三次提交之后才回退版本

4.4.3 reset 命令的 3 个参数

使用git help <command>命令用浏览器查看特定命令的本地帮助文件,如git help reset

–soft
仅在本地库移动HEAD指针。

image-20220827222244789

–mixed

在本地库移动HEAD指针,且重置暂存区。

image-20220827222307688

–hard

在本地库移动HEAD指针,且重置暂存区和工作区。

image-20220827222526891

4.5 文件的删除与找回

前提:文件存在时的状态提交到了本地库。
核心:
1.文件删除前已提交到本地库:git reset --hard <HistoricalRecords>
2.文件删除前未提交到本地库:git reset --hard HEAD

4.5.1 创建待删除文件

创建test2.txt文件,并写入一行内容:test2。

添加到暂存区后提交:

image-20220827222902821

4.5.2 删除文件

删除文件

rm -rf 文件名 通知要删除某文件

git rm 文件名 删除缓存区的该文件

git reset . 清空暂存区所有文件

git commit -m"注释" 将仓库文件删除

使用rm test2.txt命令删除test2.txt文件。

image-20220827223002700

删除后的状态

image-20220827223027325

暂存并提交

image-20220827223136817

4.5.3 找回文件

将版本回退到删除文件前的那个版本,即可完成对文件的找回。

image-20220827224402028

若文件的删除变化只添加 (add) 到了暂存区而未提交 (commit) 到本地库,则可使用git reset --hard HEAD命令找回文件。

4.6 文件差异性比较

对于test1.txt文件,修改前:

image-20220827224506801

修改后:

image-20220827224545434

  • 使用git diff <filename>命令默认用于当前文件与暂存区对应文件的差异比较:

  • 若使用git diff <hash_len_7|HEAD|HEAD^[^...]> <filename>命令,则可用于当前文件与特定历史版本或已暂存前文件的差异比较。

  • 使用不带文件名的diff命令则可比较工作区的所有文件。

image-20220827224705855

4.7 分支管理

Git 分支是由指针管理起来的,可以快速创建、切换、合并与删除,适用于大型项目的开发。在分支上开发,调试后合并到主分支的策略使每个人的开发模块式相互独立不影响到其他人。
1.主分支(默认的master分支)只用来发布重大版本更新(各版本可以有不同的标签以便于查找);
2.日常开发应该在其他分支上完成,如develop
3.对于新增功能 (feature) 、用于预发布 (release) 、Bug 修复 (bug/hot_fix) 的临时性分支,应在使用完毕后及时删除,以免分支的混乱。
4.多人开发时,可分别创建自己专属的分支,当阶段性工作完成后应该合并到上级分支。

image-20220827224809698

4.7.1 创建分支

使用git branch <BranchName>命令创建名为<BranchName>的新分支,如git branch hot_fix

4.7.2 查看分支

使用git branch -v命令可查看分支的详细 (verbose) 信息(哈希值和名称)。

image-20220827224931315

列出全部分支后,分支名称前以星号*标注的是当前分支。
当前分支已在各命令行的括号()中提及。

4.7.3 切换分支

使用git checkout <BranchName>切换到指定分支,如git checkout hot_fix

image-20220827225046032

4.7.4 合并分支

hot_fix分支中产生修改:

image-20220827225236563

使用git checkout master命令切换到接受合并的分支后,在使用git merge <BranchName>命令合并分支:

image-20220827225451370

4.7.5 分支合并的冲突产生

分支的同一位置同时发生不同的修改时,将在相互合并分支时产生冲突。需要执行手动的冲突解决。
hot_fix分支上修改,添加到暂存区后提交:

image-20220827225832007

master分支中的同一位置做出不同的修改,添加到暂存区后提交

image-20220827230801336

并尝试将hot_fix合并到master

image-20220827230808987

自动合并失败;需要手动修复冲突,然后提交结果。

4.7.6 分支合并的冲突解决

image-20220827230851233

不同于 SVN,Git 产生冲突后,不会产生新的额外文件。

对于产生冲突的文件,Git 会在冲突发生出做出特定的标记:

image-20220827230923330

hello git!
ds
<<<<<<< HEAD         ---
hot_fix2:master		 --- 这是当前分支的内容
=======				
hot_fix2			---
>>>>>>> hot_fix		 --- 这是用于合并的内容

1.编辑文件,删除特殊符号,把文件修改到满意为止后保存退出;
2.使用git add <filename>命令将此文件添加暂存区;
3.使用git commit -m "fix merge"命令提交冲突修复(执行冲突修复时不能添加具体的文件名)。

image-20220827231307442

4.7.7 删除分支

注意在删除分支时要退出该分支

1 先切换到别的分支: git checkout master

2 删除本地分支: git branch -d hot_fix

3 若是删除不了能够强制删除,git branch -D hot_fix

4 有必要的状况下,删除远程分支:git push origin --delete hot_fix

image-20220827231520070

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

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

相关文章

[Cesium学习]

Popup弹窗 Cesium点位弹窗_cesium popup弹窗-CSDN博客 Cesium构造popup弹窗函数_cesium popup-CSDN博客 开发之家 - Cesium构造popup弹窗函数 GitHub - cesium-plugin/cesium-popup-es6: 气泡弹窗 热力图分析 // 创建Cesium Viewer实例 const viewer new Cesium.Viewer(c…

C#中使用Mysql批量新增数据 MySqlBulkCopy

在C#中使用MySqlBulkCopy类来批量复制数据到MySQL数据库&#xff0c;首先需要确保你的项目中已经引用了MySQL Connector。以下是使用MySqlBulkCopy的基本步骤&#xff1a; 1.安装MySQL Connector。 可以通过NuGet安装MySQL Connector&#xff1a; 2.在代码中引用必要的命名空间…

安装 JDK 17

安装包 百度网盘 提取码&#xff1a;6666 安装步骤 双击下载得到的安装包&#xff0c;开始安装&#xff1a; 正在安装&#xff1a; 安装完成&#xff1a; 安装路径下&#xff0c;多出来了很多新的内容。安装文件夹所包含的内容及作用&#xff1a; src 是 JDK 的源码包。类库…

DevExpress WPF中文教程:Grid - 如何向项目添加GridControl并绑定到数据

DevExpress WPF拥有120个控件和库&#xff0c;将帮助您交付满足甚至超出企业需求的高性能业务应用程序。通过DevExpress WPF能创建有着强大互动功能的XAML基础应用程序&#xff0c;这些应用程序专注于当代客户的需求和构建未来新一代支持触摸的解决方案。 无论是Office办公软件…

VueRouter路由与Vuex状态管理

前言 随着前端技术的快速发展和前后端分离架构的普及&#xff0c;单页面应用&#xff08;SPA&#xff09;已成为现代Web开发的主流。在SPA中&#xff0c;前端路由和状态管理扮演着至关重要的角色。Vue3作为当前流行的前端框架之一&#xff0c;提供了强大的路由&#xff08;Vue …

sqli-labs 靶场 less-7 第七关详解:OUTFILE注入与配置

SQLi-Labs是一个用于学习和练习SQL注入漏洞的开源应用程序。通过它&#xff0c;我们可以学习如何识别和利用不同类型的SQL注入漏洞&#xff0c;并了解如何修复和防范这些漏洞。Less 7 SQLI DUMB SERIES-7判断注入点 进入页面中&#xff0c;并输入数据查看结果。 发现空数据提…

【JS实战03】学生信息的添加与删除

说明&#xff1a;本文章提供相应源码&#xff0c;需要到主页资源栏下载&#xff0c;并搭配源码看本文档&#xff1b;重点阐述每个JS模块实现过程中的重难点问题。 一&#xff1a;录入模块 1 渲染数据思路 减少DOM相关操作&#xff0c;避免因过多的DOM操作造成程序运行速度的…

机车 - 安驾培训记录

1&#xff0c;先学倒车后扶车。 先断电。脚蹬在外的话要展开&#xff0c;防止推过头。 可以挂档就挂到1档。可以用皮套把刹车拉紧&#xff0c;或手捏在刹车上。防止下坡溜车或扶起时车不稳。 站在车倒向的一侧&#xff0c;车把向内&#xff0c;方便一手抓车把&#xff0c;一…

【iOS】内存泄漏检查及原因分析

目录 为什么要检测内存泄漏&#xff1f;什么是内存泄漏&#xff1f;内存泄漏排查方法1. 使用Zombie Objects2. 静态分析3. 动态分析方法定位修改Leaks界面分析Call Tree的四个选项&#xff1a; 内存泄漏原因分析1. Leaked Memory&#xff1a;应用程序未引用的、不能再次使用或释…

CTFHUB-SQL注入-字符型注入

目录 查询数据库名 查询数据库中的表名 查询表中数据 总结 此题目和上一题相似&#xff0c;一个是整数型注入&#xff0c;一个是字符型注入。字符型注入就是注入字符串参数&#xff0c;判断回显是否存在注入漏洞。因为上一题使用手工注入查看题目 flag &#xff0c;这里就不…

基于微信小程序的社区志愿者服务平台 _8xh87【已测试】

前言&#xff1a;&#x1f469;‍&#x1f4bb; 计算机行业的同仁们&#xff0c;大家好&#xff01;作为专注于Java领域多年的开发者&#xff0c;我非常理解实践案例的重要性。以下是一些我认为有助于提升你们技能的资源&#xff1a; &#x1f469;‍&#x1f4bb; SpringBoot…

轻松掌握系统概况,提升工作效率

作为 Linux 系统管理员,我们经常需要了解系统的基本状况,比如当前时间、系统版本、内核信息、CPU 型号、内存使用等等。但是每次手动执行各种命令来获取这些信息,无疑是一件非常繁琐的事情。 幸运的是,我们可以通过编写一个简单的 shell 脚本来一键获取这些系统信息。让我们一…

Linux用户和用户组的管理

目录 前言一、系统环境二、Linux用户组的管理2.1 新增用户组2.2 删除用户组2.3 修改用户组2.4 查看用户组 三、Linux用户的管理3.1 新增用户3.2 删除用户3.3 修改用户3.4 查看用户3.5 用户口令&#xff08;密码&#xff09;的管理 总结 前言 本篇文章介绍如何在Linux系统上实现…

Aethir: 破局算力瓶颈,构建AI时代去中心化云基础设施

科技的每一次飞跃都在重新塑造世界&#xff0c;而近年来&#xff0c;跨越式的技术革新再次引发了深刻的变革&#xff0c;那就是人工智能&#xff08;AI&#xff09;。 人工智能已然超越了此前的所有技术概念&#xff0c;成为了继互联网之后的下一个巨大浪潮。从自动驾驶汽车到…

ipv6有状态分配地址

RA报文M/O标志位 设备在获取IPv6地址等信息时&#xff0c;会先发送RS报文请求链路上的路由设备&#xff0c;路由设备受到RS报文后会发送相应的RA报文来表示自身能够提供的IPv6服务类型。 对于RA报文&#xff0c;根据其M字段和O字段确定其获取IPv6地址的模式&#xff1a; M/O都…

python后端结合uniapp与uview组件tabs,实现自定义导航按钮与小标签颜色控制

实现效果&#xff08;红框内&#xff09;&#xff1a; 后端api如下&#xff1a; task_api.route(/user/task/states_list, methods[POST, GET]) visitor_token_required def task_states(user):name_list [待接单, 设计中, 交付中, 已完成, 全部]data []color [#F04864, …

电脑缺失msvcp110.dll文件的解决方法,总结5种靠谱的方法

在计算机使用过程中&#xff0c;我们可能会遇到一些错误提示&#xff0c;其中之一就是“找不到msvcp110.dll”。这个错误提示通常出现在运行某些软件时&#xff0c;那么&#xff0c;它究竟会造成哪些问题呢&#xff1f; 一&#xff0c;msvcp110.dll文件概述 msvcp110.dll是Mic…

各种空气能热泵安装图

空气能热泵安装图 循环式空气能热泵安装图 直热循环式空气能热泵安装图 泳池空气能热泵安装图 循环式水源热泵热安装系统原理图 直热循环式水源热泵安装系统图 空气水源热泵安装图

sqli-labs 靶场 less-8、9、10 第八关到第十关详解:布尔注入,时间注入

SQLi-Labs是一个用于学习和练习SQL注入漏洞的开源应用程序。通过它&#xff0c;我们可以学习如何识别和利用不同类型的SQL注入漏洞&#xff0c;并了解如何修复和防范这些漏洞。Less 8 SQLI DUMB SERIES-8判断注入点 当输入id为1时正常显示&#xff1a; 加上单引号就报错了 …

2024年【天津市安全员C证】免费试题及天津市安全员C证试题及解析

题库来源&#xff1a;安全生产模拟考试一点通公众号小程序 天津市安全员C证免费试题是安全生产模拟考试一点通生成的&#xff0c;天津市安全员C证证模拟考试题库是根据天津市安全员C证最新版教材汇编出天津市安全员C证仿真模拟考试。2024年【天津市安全员C证】免费试题及天津市…