Git的概念
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_c8master
在切换到master,合并branch_c6_c8到master
user@jinbo:t$ git checkout master
切换到分支 'master'
user@jinbo:t$ git merge branch_c6_c8
自动合并 a.txt
冲突(内容):合并冲突于 a.txt
自动合并失败,修正冲突然后提交修正的结果。
合并冲突后,再重新提交。
参考:
GIT压缩多次提交记录为一次
git将多次commit提交合并为一次
修改最近的commit
修改commit信息主要有这几种情况
- 刚刚commit,还没有push,使用git commit --amend;
- 刚刚push,要修改最近一个push的commit信息,使用git commit --amend;
- 修改历史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, withgit commit --amend Once you are satisfied with your changes, rungit 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
相关文章:
Git的概念
Git 一些概念 **工作区:**电脑上你能看到的目录 **版本库:**工作区的隐藏目录.git。含 暂存区:git add后但未git commit的文件修改被添加到暂存区本地分支:git commit后,但未git push,即把暂存区的所有…...
【每日刷题】Day58
【每日刷题】Day58 🥕个人主页:开敲🍉 🔥所属专栏:每日刷题🍍 🌼文章目录🌼 1. 3038. 相同分数的最大操作数目 I - 力扣(LeetCode) 2. 868. …...
Python 的七个HTTP请求库对比
Python HTTP请求库对比 库名称特点优点缺点requests简单易用的HTTP库,基于urllib3。- 语法简洁- 社区支持强大- 易于上手和维护- 阻塞式调用,不支持异步操作- 相比aiohttp体积较大http.clientPython标准库中的低级HTTP库。- 无需安装第三方库- 提供底层…...
顶顶通呼叫中心中间件-如何配置识别不同语种的ASR
文章目录 前言联系我们创建不同语种的语音识别任务开始对接识别不同语种的ASR重启 asrproxy 程序使用识别不同语种的ASR 前言 之前讲过顶顶通的 asrproxy 程序如何对接第三方的ASR,比如:阿里云的ASR。不知道如何对接的,可以参考:…...
C# SolidWorks 二次开发-显示配置
在 SolidWorks 的二次开发中,显示配置(Display States)是一个非常重要的功能。显示配置允许用户在同一个配置(Configuration)下保存不同的显示状态,如隐藏或显示的零件、不同的颜色和材质等。本文将向新的开…...
PXE自动装机
一、PXE概述 PXE:c/s架构,允许客户端通过网络从远程服务器(服务端)下载引导镜像,加载安装文件,实现自动化安装操作系统。 c/s 架构:服务端和客户端都可以是多台。 无人值守:安装选…...
MQ之初识kafka
1. MQ简介 1.1 MQ的诞生背景 以前网络上的计算机(或者说不同的进程)传递数据,通信都是点对点的,而且要实现相同的协议(HTTP、 TCP、WebService)。1983 年的时候,有个在 MIT 工作的印度小伙突发…...
linux驱动学习(七)之混杂设备
需要板子一起学习的可以这里购买(含资料):点击跳转 一、混杂设备 混杂设备也叫杂项设备,是对普通的字符设备(struct cdev)的一种封装,设计目的就是为了简化字符设备驱动设计的流程。具有以下特点: 1) 主设备号为10&a…...
【数据结构与算法 | 堆篇】力扣215, 703
1. 力扣215 : 数组中的第k个最大元素 (1). 题 给定整数数组 nums 和整数 k,请返回数组中第 k 个最大的元素。 请注意,你需要找的是数组排序后的第 k 个最大的元素,而不是第 k 个不同的元素。 你必须设计并实现时间复杂度为 O(n) 的算法解…...
项目经理进入职场都会经历的三个阶段
对于项目经理而言,进入职场是一个不断学习和成长的过程。在这个过程中,项目经理通常会经历三个主要阶段,每个阶段都有其独特的特点和挑战。 一、基础建设与学习阶段 对于新入行的项目经理来说,最初的阶段主要是基础技能的积累和…...
消防设施工程乙级资质全解析:申请条件与流程“
消防设施工程乙级资质全解析:申请条件与流程 消防设施工程乙级资质,作为衡量企业从事特定规模消防设施设计能力的重要标尺,对于想要在消防工程领域拓展业务的企业而言至关重要。本文将全面解析申请消防设施工程乙级资质所需的条件、流程及相…...
【C语言】03.分支结构
本文用以介绍分支结构,主要的实现方式为if语句和switch语句。 一、if语句 1.1 if语句 if (表达式)语句表达式为真则执行语句,为假就不执行。在C语言中,0表示假,非0表示真.下图表示if的执行过程: 1.2 else语句 当…...
uniapp手机屏幕左滑返回上一页支持APP,H5
核心:touchstart"touchStart" touchend"touchEnd" 代码示例: <template><view class"payPasswordSetting" touchstart"touchStart" touchend"touchEnd"></view> </template&g…...
【Java毕业设计】基于JavaWeb的洗衣店管理系统
文章目录 摘要ABSTRACT目 录1 概述1.1 研究背景及意义1.2 国内外研究现状1.3 拟研究内容1.4 系统开发技术1.4.1 SpringBoot框架1.4.2 MySQL数据库1.4.3 MVC模式 2 系统需求分析2.1 可行性分析2.2 功能需求分析 3 系统设计3.1 功能模块设计3.2 系统流程设计3.3 数据库设计3.3.1 …...
使用sqlldr向oracle导入大量数据
(1)在Oracle主机安装oracle客户端 sqlldr,在命令行输入sqlldr,若有help指导即已经安装了; (2)创建一个xxx.ctl文件 这个文件是执行导入数据的语句,其中包含需要导入的数据&#x…...
Milvus LIKE操作符
在Milvus中,虽然LIKE操作符被用于模糊匹配字符串,但其支持的模式匹配能力有限。根据你收到的错误信息,Milvus目前只支持两种类型的LIKE模式匹配: 前缀匹配,例如LIKE ab%,这意味着任何以ab开头的字符串都会…...
iQOO neo 5精简内置组件
无他!系统自带了太多组件,都用不到,连打开都不曾打开过。 下午整理一篇精简组件的列表,各自按照各自的需要进行精简哦。别盲目跟风,要不然手机使用会出问题。 精简步骤 使用任意刷机工具,开启手机的开发权限,然后adb连接 删除组件列表如下: pm uninstall --user 0…...
为什么给网站安装SSL证书之后还是有被提示不安全?
分为两种情况一种是安装了付费证书之后还是显示无效,另一种是安装了免费SSL证书的。 付费SSL证书:直接找厂商帮助解决遇到的问题,一般都是有专业的客服来对接这些的。 免费SSL证书:出现这种情况的原因会有很多。因为免费SSL证书的…...
创建Frame单例,实现WPF页面跳转
需求: 有一个F0View主页面入口,三个子页面(First.xaml/Second.xaml/Third.xaml)用Frame默认加载第一个页面 First.xaml。实现三个页面之间顺序跳转,并且每个页面只初始化一次。 实现: 1,将三…...
正宇软件助力江西数字人大建设,高效解决群众“急难愁盼”问题
近日,赣州市南康区群众通过“江西数字人大”小程序成功解决道路塌陷等民生问题,引发社会广泛关注。这一成功案例不仅彰显了“数字人大”在解决群众“急难愁盼”问题中的重要作用,也凸显了江西地区近年来在数字化人大建设方面的显著成效。正宇…...
SkyWalking 10.2.0 SWCK 配置过程
SkyWalking 10.2.0 & SWCK 配置过程 skywalking oap-server & ui 使用Docker安装在K8S集群以外,K8S集群中的微服务使用initContainer按命名空间将skywalking-java-agent注入到业务容器中。 SWCK有整套的解决方案,全安装在K8S群集中。 具体可参…...
k8s从入门到放弃之Ingress七层负载
k8s从入门到放弃之Ingress七层负载 在Kubernetes(简称K8s)中,Ingress是一个API对象,它允许你定义如何从集群外部访问集群内部的服务。Ingress可以提供负载均衡、SSL终结和基于名称的虚拟主机等功能。通过Ingress,你可…...
django filter 统计数量 按属性去重
在Django中,如果你想要根据某个属性对查询集进行去重并统计数量,你可以使用values()方法配合annotate()方法来实现。这里有两种常见的方法来完成这个需求: 方法1:使用annotate()和Count 假设你有一个模型Item,并且你想…...
【CSS position 属性】static、relative、fixed、absolute 、sticky详细介绍,多层嵌套定位示例
文章目录 ★ position 的五种类型及基本用法 ★ 一、position 属性概述 二、position 的五种类型详解(初学者版) 1. static(默认值) 2. relative(相对定位) 3. absolute(绝对定位) 4. fixed(固定定位) 5. sticky(粘性定位) 三、定位元素的层级关系(z-i…...
【android bluetooth 框架分析 04】【bt-framework 层详解 1】【BluetoothProperties介绍】
1. BluetoothProperties介绍 libsysprop/srcs/android/sysprop/BluetoothProperties.sysprop BluetoothProperties.sysprop 是 Android AOSP 中的一种 系统属性定义文件(System Property Definition File),用于声明和管理 Bluetooth 模块相…...
[Java恶补day16] 238.除自身以外数组的乘积
给你一个整数数组 nums,返回 数组 answer ,其中 answer[i] 等于 nums 中除 nums[i] 之外其余各元素的乘积 。 题目数据 保证 数组 nums之中任意元素的全部前缀元素和后缀的乘积都在 32 位 整数范围内。 请 不要使用除法,且在 O(n) 时间复杂度…...
【HarmonyOS 5 开发速记】如何获取用户信息(头像/昵称/手机号)
1.获取 authorizationCode: 2.利用 authorizationCode 获取 accessToken:文档中心 3.获取手机:文档中心 4.获取昵称头像:文档中心 首先创建 request 若要获取手机号,scope必填 phone,permissions 必填 …...
PostgreSQL——环境搭建
一、Linux # 安装 PostgreSQL 15 仓库 sudo dnf install -y https://download.postgresql.org/pub/repos/yum/reporpms/EL-$(rpm -E %{rhel})-x86_64/pgdg-redhat-repo-latest.noarch.rpm# 安装之前先确认是否已经存在PostgreSQL rpm -qa | grep postgres# 如果存在࿰…...
pikachu靶场通关笔记19 SQL注入02-字符型注入(GET)
目录 一、SQL注入 二、字符型SQL注入 三、字符型注入与数字型注入 四、源码分析 五、渗透实战 1、渗透准备 2、SQL注入探测 (1)输入单引号 (2)万能注入语句 3、获取回显列orderby 4、获取数据库名database 5、获取表名…...
AI语音助手的Python实现
引言 语音助手(如小爱同学、Siri)通过语音识别、自然语言处理(NLP)和语音合成技术,为用户提供直观、高效的交互体验。随着人工智能的普及,Python开发者可以利用开源库和AI模型,快速构建自定义语音助手。本文由浅入深,详细介绍如何使用Python开发AI语音助手,涵盖基础功…...
