Git的概念

news2025/1/13 7:32:09

Git

一些概念

**工作区:**电脑上你能看到的目录

**版本库:**工作区的隐藏目录.git。含

  • 暂存区:git add后但未git commit的文件修改被添加到暂存区
  • 本地分支:git commit后,但未git push,即把暂存区的所有内容提交到本地分支

练习 git 的在线网站

Git 基本操作

初始化仓库

# 下载一个 github 仓库
$ git clone [url]

# 初始化仓库
$ git init

# 新建一个目录,将其初始化为 Git 代码库
$ git init [project-name]

配置

# 显示当前的 Git 配置
$ git config --list

# 编辑 Git 配置文件
$ git config -e 

增加/删除文件

# 添加指定文件到暂存区
$ git add [file1] [file2] ...

# 添加指定目录到暂存区,包括子目录
$ git add [dir]

# 添加当前目录的所有文件到暂存区
$ git add -A 

# 提交新文件和被修改的文件,不包括被删除的文件  
$ git add .

# 提交被修改和被删除的文件,不包括新文件  
$ git add -u

# 停止跟踪指定文件,该文件会保留在工作区
# 停止跟踪后修改了停止跟踪的文件,并且 git add 到暂存区,又会再次跟踪
$ git rm --cached [file1] [file2]...

# 停止跟踪指定文件夹(可含子文件夹),该文件会保留在工作区
$ git rm --cached -r [dir]

# 删除工作区文件,使用 git 的这个命令不如用 shell 的 rm 命令,递归文件夹删除用 -rf
$ git rm -f [file1] [file2] ...

# 重命名暂存区文件(同时重命名工作区的文件名),重命名的文件被放入暂存区
$ git mv [file-original] [file-renamed]

代码提交

# 提交暂存区文件到本地仓库
$ git commit -m [message]

# 提交暂存区的指定文件到仓库区
$ git commit [file1] [file2] ... -m [message]

# 使用一次新的 commit,替代上一次提交
# 如果代码没有任何新变化,则用来改写上一次 commit 的提交信息
$ git commit --amend -m [message]

分支

# 列出所有本地分支
$ git branch

# 列出所有远程分支
$ git branch -r

# 列出所有本地分支和远程分支
$ git branch -a

# 新建一个分支,但依然停留在当前分支
$ git branch [branch-name]

# 新建一个分支,并切换到该分支
$ git checkout -b [branch-name]

# 新建一个分支,与指定的远程分支建立追踪关系
$ git branch --track [branch-name] [remote-branch-name]

# 切换到指定分支,并更新工作区
$ git checkout [branch-name]

# 合并指定分支到当前分支
$ git merge [branch-name]

# 推送分支到远程
$ git push origin [branch-name]

# 删除分支
$ git branch -d [branch-name]
$ git branch -D [branch-name]

# 删除远程分支
$ git push origin --delete <branch-name>
$ git branch -dr <remote/branch>

# 修改本地分支名字
git branch -m old-name new-name

查看信息

# 查看暂存区状态
$ git status

# 显示当前分支的版本历史
$ git log

# 显示commit历史,以及每次commit发生变更的文件
$ git log --stat

# 显示暂存区和工作区的差异
$ git diff

# 显示工作区与当前分支最新commit之间的差异
$ git diff HEAD

# 显示某次提交的数据和内容变化
$ git show [commit]

# 显示某次提交时,某个文件的内容
$ git show [commit]:[filename]

# 显示当前分支的最近几次提交
$ git reflog

远程同步

# 下载远程仓库的所有变动
$ git fetch [remote]

# 显示所有远程仓库
$ git remote -v

# 获取远程的最新提交,并合并到本地工作目录,而且在合并过程中不会经过我们的审查,如果不仔细检查,这样很容易遇到冲突
$ git pull [remote] [branch]

# 把远程提交拉取到本地仓库,而不是本地工作目录,它不会自行将这些新数据合并到当前工作目录中,我们需要继续执行git merge才会把这些变动合并到当前工作目录。相比之下,git fetch是一个更安全的选择,因为它从你的远程仓库拉入所有的提交,但不会对你的本地文件做任何修改。
$ git fetch [remote] [branch]

# 上传本地指定分支到远程仓库
$ git push [remote] [branch]

# 强行推送当前分支到远程仓库,即使有冲突
$ git push [remote] --force

# 推送所有分支到远程仓库
$ git push [remote] --all

撤销

# 撤销工作区的所有修改
$ git checkout .

# 恢复暂存区的指定文件到工作区
$ git checkout [file]

# 恢复某个 commit 的指定文件到工作区
$ git checkout [commit] [file]

# 恢复上一个 commit 的所有文件到工作区,即撤销工作区的所有修改
$ git checkout .

# 重置暂存区的指定文件,与上一次 commit 保持一致,但工作区不变
$ git reset [file]

# 重置暂存区与工作区,与上一次 commit 保持一致
$ git reset --hard

# 重置当前分支的指针为指定 commit,同时重置暂存区,但工作区不变
$ git reset [commit]

# 重置当前分支的 HEAD 为指定 commit,同时重置暂存区和工作区,与指定commit 一致
$ git reset --hard [commit]

# 重置当前 HEAD 为指定 commit,但保持暂存区和工作区不变
$ git reset --keep [commit]

# 新建一个 commit,用来撤销指定 commit
# 后者的所有变化都将被前者抵消,并且应用到当前分支
$ git revert [commit]

更改历史

# 删除历史里的文件path-to-your-remove-file。
# 注意一点,这里的文件或文件夹,都不能以 '/' 开头,否则文件或文件夹会被认为是从 git 的安装目录开始。
# 如果你要删除的目标不是文件,而是文件夹,那么请在 `git rm --cached' 命令后面添加 -r 命令,表示递归的删除(子)文件夹和文件夹下的文件,类似于 `rm -rf` 命令。
$ git filter-branch --force --index-filter 'git rm --cached --ignore-unmatch path-to-your-remove-file' --prune-empty --tag-name-filter cat -- --all

查看改动

git diff命令可以查看当前工作区(add前)与暂存区(add后commit前)的差别。也就是说可以查看到当前我们修改或者是添加的,但是还没有add进暂存区的代码。它会列出改动前后的对比,方便我们进行查看和修改。

user@jinbo:t$ git diff
diff --git a/a.txt b/a.txt
index a801aea..84692d5 100644
--- a/a.txt
+++ b/a.txt
@@ -1,2 +1,2 @@
 a.txt commit1
-a.txt commit2
\ No newline at end of file
+a.txt commit2 -
\ No newline at end of file

由于git diff是显示所有的文件改动,当改动量较大时,不方便看你呢,所以可以通过 git diff + 文件路径查看某一个文件的具体改动,如 git diff path/file.cpp

git diff --cached:在不加任何参数的情况下查看的是工作区(add命令之前)的代码和暂存区的差别,如果已经把所有代码都add进来了,那么当运行git diff是不会显示任何内容的,这是因为我们已经把代码提交到暂存区了,不加参数的时候是比较的工作区和暂存区的差别。这个时候我们再想看diff,想看的其实是暂存区和本地git仓库的差别。这时可以通过--cached参数来实现,--cached参数后面同样可以跟上文件路径,查看某一个具体文件的改动。

查看提交

git log -p -n:运行git log的时候只会展示提交相关的信息,是不会把每一次改动的内容都展示出来的,一则没有必要,二则未免太多了。但是有的时候我们会希望看到每一个commit当中改动的究竟是什么,如果通过git diff一个一个查看也太麻烦了。这个时候就可以用上参数来实现这点,只需要在git log后面加上-p,它就会展示出每一个commit中的改动。由于commit当中的改动量可能很大,所以我们这样查看到的内容也会非常多。我们可以在-p后面再加上一个-n表示我们想要查看的最近几条commit信息,比如git log -p -2查看的就是最近两条提交信息。后面还可以接grep查看指定关键字的修改。

git log --stat -n:有的时候只想查看每一次commit到底有多少改动量,而不想知道具体的改动是什么,可以使用--stat参数。如果只想查看最近几次的commit的改动量,只需要再加 -n。如果想把改动的内容显示处理,可以加 -p

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

git log --graph:可以展示提交的一个树形分支结构

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

git log --pretty:支持DIY自己想要的log展示,比如常用的是git log --pretty=oneline,这里的oneline是一种格式,表示单行展示,也就是会把commit展示的信息压缩成一行。关于--pretty更多用法有需求的时候再查,这里不再记录了。

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

参考学会这三个命令,你就不再是git只会用三板斧的菜鸟了

合并多次commit为一次

git rebase -i HEAD~n:可以将从最后一次提交往前的n次提交合并为一次。

如最近的三次提交是

user@jinbo:t$ git log --pretty=oneline
3088bc081cf8fd9c36a117085877e9ec7e38e3cc (HEAD -> master) a.txt c3
e88bf8637ca31fd95a36a47d20837bb3d3b650c3 a.txt c2
4ad0c43bd8d1cfb91542f1d09e47ebdefe825c25 a.txt commit1

希望合并最近的两次提交,使用命令git rebase -i HEAD~2,将除了第一个pick外的其它pick改为s,即squash。之后保存退出。

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

再次查看commit记录,发现commit第一次记录3088bc和第二次记录 e88bf8 合并为一次提交7d988f。

user@jinbo:t$ git log --pretty=oneline
7d988f2cfa02fd013d5dde9de03368f6aa01a5f6 (HEAD -> master) a.txt c2
4ad0c43bd8d1cfb91542f1d09e47ebdefe825c25 a.txt commit1

参考https://www.jianshu.com/p/66cece71b41d

git rebase -i commit_id1 commit_id2:可以合并从commit_id1之后到commit_id2(含)之间的commit

例如:

user@jinbo:t$ git log --pretty=oneline
d82301239211e6bd474356c22d6efc1f2d28e75d (HEAD -> master) c8
a649ba5230038f8fdc7785a360604ef45c6e98ec merge branch new
42d747cc69ee9424a5c4cc4df1dc0124b2774c0c c5
e86db72752ab56086b18ed6c4912e820dbe05376 c7
a12595a769124c371d3a023ff82c2f58db150741 c6
c80902f12e12f1e0206667ca7c5d94f88ddd9510 c5
1feb2001fb0b947860b6e052c00269eba52d09f8 c4
7d988f2cfa02fd013d5dde9de03368f6aa01a5f6 a.txt c2
4ad0c43bd8d1cfb91542f1d09e47ebdefe825c25 a.txt commit1

git rebase -i c80902 d82301会合并主题是c6,c7,c6,merge branch new,c8的这些提交。然后将除了第一个pick外的其它pick改为s,即squash。再保存退出。

保存上面提交后,查看分支信息,当前分支并不在master上了,这个分支并不会保存,只是我们压缩提交记录后的一个临时分支。所以要基于当前临时分支创建新分支。

user@jinbo:t$ git checkout -b branch_c6_c8
切换到一个新分支 'branch_c6_c8'
user@jinbo:t$ git branch
* branch_c6_c8
  master

在切换到master,合并branch_c6_c8master

user@jinbo:t$ git checkout master 
切换到分支 'master'
user@jinbo:t$ git merge branch_c6_c8 
自动合并 a.txt
冲突(内容):合并冲突于 a.txt
自动合并失败,修正冲突然后提交修正的结果。

合并冲突后,再重新提交。

参考:

GIT压缩多次提交记录为一次

git将多次commit提交合并为一次

修改最近的commit

修改commit信息主要有这几种情况

  1. 刚刚commit,还没有push,使用git commit --amend;
  2. 刚刚push,要修改最近一个push的commit信息,使用git commit --amend;
  3. 修改历史push的commit信息,使用git rebase -i HEAD~n(其中n为记录数),配合2中的命令

注意:

其中1、2两种情况的修改方式是一样的,但是git log的记录是不同的

第三种方式也是把需要修改的记录调整为最新的提交,然后使用2的方式修改,示例如下:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

我们希望修改之前的第五个提交:git rebase -i HEAD~5

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

在弹出的界面中,将第一个 pick 改成 e,wq保持退出后,终端打印

jinbo@fang:/mnt/d/gitme/linux/git$ git rebase -i HEAD~5
Stopped at 896ea56...  doc(toc): modify the content of readme.md
You can amend the commit now, with

  git commit --amend 

Once you are satisfied with your changes, run

  git rebase --continue

按照指示添加 commit

git commit --amend

弹出如下界面,我们修改commit记录如下图所示

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

再输入命令

jinbo@fang:/mnt/d/gitme/linux/git$ git rebase --continue
Successfully rebased and updated refs/heads/master.

此时 log 内容为

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

打 patch

对未提交的代码打 patch

# 对指定的文件的修改打 patch
git diff 文件名 > test.patch

# 由于没有指定修改的文件,所以默认把所有修改的文件都打 patch,同时还需要注意,这里是本地修改的没有执行add缓存的
git diff > test.patch  

# 如果已经执行git add,再想打 patch 可以使用
git diff --cached >  test.patch

对提交的代码打 patch

git format-patch commit_id1 commit_id2  
# 也可以使用 git format-patch -1 ,指为最近 1 次提交的代码打 patch,-2 指为最近的两次提交打 patch,会生成两个文件,分别是两次提交的 patch)

应用 patch

git am xxx.patch

恢复删除的远程分支

实际工作中,可能既删除了本地代码,也删除了远程分支,但还是可以恢复的。

查看reflog,找到最后一次commit id

git reflog --date=iso

reflog是reference log的意思,也就是引用log,记录HEAD在各个分支上的移动轨迹。选项 --date=iso,表示以标准时间格式展示。这里

为什么不用git log?git log是用来记录当前分支的commit log,分支都删除了,找不到commit log了。但可以找到目标分支最后一次的commit id

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

比如这里,我们将远程分支master删除了,但是我们找到了从分支t切换到master的这个移动轨迹0342d3f HEAD@{2023-04-04 23:19:04 +0800}: checkout: moving from t to master,那么可以根据0342d3f切出分支:

git checkout -b recovery 0342d3f
Switched to a new branch 'recovery'

切出分支后,本地有分支了,再push到远程仓库就可以了

 git push origin recovery 

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

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

相关文章

【云原生】kubernetes中secret原理详解与应用实战

✨✨ 欢迎大家来到景天科技苑✨✨ &#x1f388;&#x1f388; 养成好习惯&#xff0c;先赞后看哦~&#x1f388;&#x1f388; &#x1f3c6; 作者简介&#xff1a;景天科技苑 &#x1f3c6;《头衔》&#xff1a;大厂架构师&#xff0c;华为云开发者社区专家博主&#xff0c;…

51单片机-实机演示(LED点阵)

目录 前言: 一.线位置 二.扩展 三.总结 前言: 这是一篇关于51单片机实机LED点阵的插线图和代码说明.另外还有一篇我写的仿真的连接在这:http://t.csdnimg.cn/ZNLCl,欢迎大家的点赞,评论,关注. 一.线位置 接线实机图. 引脚位置注意: 1. *-* P00->RE8 P01->RE7 …

JavaWeb2-Vue

Vue 前端框架&#xff0c;免除原生JS中的DOM操作简化书写 &#xff08;以前学过又忘了&#xff0c;现在才知道原来vue是前端的&#xff09; 基于MVVM思想&#xff08;model-view -viewModel&#xff09;实现数据双向绑定 model是数据模型 view负责数据展示 即DOM 中间这个负责…

EitbaseEX香港启航,携手OpenAI和路透社开发AI分析技术

全球知名的加密货币交易平台EitbaseEX宣布正式入驻香港&#xff0c;并改名为EitbaseEX。这一举措标志着EitbaseEX在亚洲市场的重要布局&#xff0c;旨在为香港及周边地区的用户提供安全、合规且高效的数字货币交易服务。与此同时&#xff0c;EitbaseEX还宣布与OpenAI和路透社展…

怎么找抖音视频素材?下载抖音的素材视频网站分享给你

在这个视觉印象至关重要的时代&#xff0c;选用高质量的视频素材对于制作抖音视频来说是关键。如果你正在寻找适合的视频素材来丰富你的抖音创作&#xff0c;以下这份详细的视频素材网站指南将帮助你迈出第一步。 蛙学府网 蛙学府网提供了丰富多样的视频素材&#xff0c;包括动…

如何新建并导入数据集并智能标注

如何新建并导入数据集并智能标注 智能标注 提交等待即可&#xff0c;智能标注结束会有难例确认&#xff0c;这个可以检查一下&#xff0c;检查完毕就自动保存标注就可以了

搭贝请假审批应用

在现代企业管理中&#xff0c;高效的请假审批系统至关重要。搭贝的请假审批应用通过简化员工的请假流程、提升管理层的工作效率&#xff0c;确保企业运作的连贯性和透明度。本文将介绍搭贝请假审批应用的主要功能模块&#xff1a;请假分析看板、请假申请审批流、请假类型维护和…

什么是振动电阻式传感器测量模块RM501/502

什么是振动电阻式传感器测量模块RM501/502 基本概念 差动电阻式传感器&#xff1a; &#xff08; Elastic wire sensor&#xff09;是以两个电阻的比值来反映被测物理量的传感器。由于是由卡尔逊教授在 1932 年研发成功&#xff0c;所以也称为卡尔逊式传感器。 因为采用的是两…

YOLOv10涨点改进:原创自研 | GhostNet融合 | 从廉价的操作中生成更多的特征图

文章目录 GhostNet理论基础实验部分改进方案新增yolov10s-ghost.yaml文件代码运行GhostNet理论基础 Ghost Module是一种模型压缩的方法,即在保证网络精度的同时减少网络参数和计算量,从而提升计算速度(speed),降低延时(latency)。Ghost 模块可以代替现有卷积网络中的每…

Glance:支持RSS的自托管仪表板

本文软件由网友 P家单推人 推荐 什么是 Glance &#xff1f; Glance 是一个自托管仪表板&#xff0c;可以显示实时 RSS 订阅、Reddit 子版块帖子、天气、书签、特定频道的最新 YouTube 视频、日历、股票信息、iframe、twitch 频道和热门游戏、GitHub 发布和网站监控等。 因为是…

M4 MacBook Pro预计将于2024年末正式亮相

M4 MacBook Pro 关于苹果即将推出的搭载AI增强功能的M4 MacBook Pro&#xff0c;传闻已经愈演愈烈。据悉&#xff0c;这款备受期待的M4芯片预计将于2024年末正式亮相&#xff0c;并且相比以往&#xff0c;它将更加注重AI性能的提升。 尽管M3系列芯片推出尚不足半年&#xff0…

RPA是什么?为啥要学习RPA,看这篇就够了

您好&#xff0c;我是码农飞哥&#xff0c;感谢您阅读本文&#xff0c;欢迎一键三连哦。 &#x1f4aa;&#x1f3fb; 1. Python基础专栏&#xff0c;基础知识一网打尽&#xff0c;9.9元买不了吃亏&#xff0c;买不了上当。 Python从入门到精通 &#x1f601; 2. 毕业设计专栏&…

碳化硅柱式膜的广泛应用

碳化硅柱式膜是一种高性能的过滤材料&#xff0c;以其独特的性质和广泛的应用领域在现代工业中占据着重要地位。以下是对碳化硅柱式膜的详细介绍&#xff1a; 一、基本概述 碳化硅柱式膜是以碳化硅超滤膜为过滤单元构成的&#xff0c;其过滤精度高达0.1微米。这种膜材料具有耐化…

apple开发者账户证书删除与下载

1.打开并登陆: Sign In - Apple 选择证书 证书管理页面 证书详情 删除或者下载证书 下载证书 删除证书

《中国数据库年度行业分析报告》节选:数据库关键技术及发展趋势

墨天轮于5月29日正式发布 《2023年中国数据库年度行业分析报告》&#xff0c;总结梳理了中国数据库行业的技术演进及趋势。作为云上数据库和数据计算领域的领先者&#xff0c;拓数派受邀参与创作&#xff0c;联合编写了《AI 时代下新一代数据仓库的演进》《从数据库到数据计算系…

谷歌的AI大变革:商业模式转型

每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗&#xff1f;订阅我们的简报&#xff0c;深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同&#xff0c;从行业内部的深度分析和实用指南中受益。不要错过这个机会&#xff0c;成为AI领…

verilog 232串口通信程序

1,串口通信协议: 通常串口的一次发送或接收由四个部分组成:起始位S、数据位D0~D7(一般为 6 位~8 位之间可变,数据低位在前)、校验位(奇校验、偶检验或不需要校验位)、停止位(通常为1位、1.5位、2位)。停止位必须为逻辑 1。在一次串口通信过程中,数据接收与发送双方…

pytest构建和测试FastAPI CURD API

文章目录 概述目标FASTAPI 介绍CRUD API 项目设置freezepipreqs 代码介绍run APIpytest测试F&Q1.执行uvicorn app.main:app --host localhost --port 8000 --reload 报错 zsh: /usr/local/bin/uvicorn: bad interpreter2.生成requirement.txt时&#xff0c;pip3 list pipre…

游戏开发指南,一个充满想象力和机遇的职业领域!

游戏是软件里常见的一种类型&#xff0c;是常见的一种计算机娱乐方式。以前的游戏偏中大型游戏居多&#xff0c;现在发展为小型游戏较多&#xff0c;尤其是微信游戏的出现更加体现了这个特点。 随着游戏产业的蓬勃发展&#xff0c;越来越多的公司开始考虑将游戏制作外包给专业…

晶圆几何量测系统支持半导体制造工艺量测,保障晶圆制造工艺质量

晶圆面型参数厚度、TTV、BOW、Warp、表面粗糙度、膜厚、等是芯片制造工艺必须考虑的几何形貌参数。其中TTV、BOW、Warp三个参数反映了半导体晶圆的平面度和厚度均匀性&#xff0c;对于芯片制造过程中的多个关键工艺质量有直接影响。 TTV、BOW、WARP对晶圆制造工艺的影响 对…