git小白进阶之路

        git是最常用的版本控制工具,我对其进行了整理后续补充,这个文档欢迎大家来讨论,当前我的视频梳理: git小白进阶之路_哔哩哔哩_bilibili,非常希望大佬们能够批评指正,并多多交流。

目录

初始配置

配置账号密码

配置ssh-key

添加公钥在远程仓库

git工作流

git文件状态

git别名

git撤销

1.从本地仓库 到 暂存区

2.从暂存区 到 工作目录

3.从本地仓库到工作目录

4.修改刚才提交的注释

5.回滚提交

git commit注释格式

git分支

拉取代码

提交代码

追溯代码

合并代码

git merge相关

git cherry-pick 相关

打补丁

git format-patch

git apply

git am

历史记录

调整历史记录

贮藏改动

git stash贮藏

列出所有贮藏的改动:

应用stash:

丢弃贮藏

远程仓库Remote

其他整理

1.解决git无法处理wsl虚拟机中的项目,

2.设置git内部环境变量

图形工具

参考文档

初始配置

配置账号密码

git config --list
# 设置git的name
git config --global user.name "determination"
# 设置git的邮箱
git config --global user.email "XXXX.@XX.conm"

配置ssh-key

ssh-keygen -t rsa -C "username@email.com"  

添加公钥在远程仓库

获取公钥:在~/.ssh目录下

C:\Users\24964\.ssh目录下

cd ~/.ssh
ls
# 查看公钥
cat id_rsa.pub

git工作流

git文件状态

对换行符的替换

git config --global core.autocrlf false

git别名

参考:Git - Git 别名

格式:git config --global alias.<­al­ias­-na­me> <co­mma­nd>

设置 Git 命令别名,例如:

$ git config --global alias.st status

# 设置commit别名
git config --global alias.ci commit
# 设置status别名
git config --global alias.st status

git撤销

https://www.cnblogs.com/lfxiao/p/9378763.html

撤销commit并保留刚才的commit:

1.从本地仓库 到 暂存区

# 不删除工作目录代码,撤销到commit到暂存区
git reset --soft HEAD^

2.从暂存区 到 工作目录

# 不删除工作目录代码,撤销到工作区
git reset HEAD .

3.从本地仓库到工作目录

# 不删除工作空间代码,撤销commit、add
git reset --mixed HEAD^
# 相当于上述两个,即 git reset --soft HEAD^ 和 git reset HEAD .


# 删除工作代码,撤销commit、add
git reset --hard HEAD^

4.修改刚才提交的注释

# 修改最后一次­提交,­可用来­修改提交信息。
git commit --amend

5.回滚提交

# 回滚提交,创建一个commit,其实内容是回滚版本的
git revert

git commit注释格式

对于小型项目格式可以参考:使用 commitizen 规范 Git 提交说明

类型

说明

example

feat

新功能

feat:添加XXX接口

fix

修复bug

fix:修复XXX bug

style

格式化变动,不影响代码逻辑

style:格式化代码

improvement

对当前功能改进

improvement:改进功能

refactor

重构

refactor:重构

test

添加或修改test代码

test:添加XX测试代码

chore

杂项,不修改源代码与测试代码

chore:

revert

撤销

revert:

git分支

git分支本质就是指向提交对象的指针,HEAD指针指向当前的本地分支。

# 查看当前本地分支
git branch

# 切换分支
git checkout <branch_name>

# 合并分支
git merge <branch_name>

默认:快进合并fast-forward merge,简单的将指针推进

非快进合并:多出一个合并节点,看起来会更清晰。

拉取代码

从远程仓库取­回所有­分支的­更新,­但不会­修改本­地工作­目录的内容,拉取后的更新需要本地再合并,此时HEAD指针不变

# 拉取仓库代码更新
git fetch

# 将会提示分支可以快进
git status

# 合并分支
git merge  或 git rebase

git pull = git fectch + git merge

拉取远程代码,并且自动与本地的合并

git pull

git pull --rebase = git fectch + git rebase

rebase 会重新应用本地的提交,这会使历史记录是线性的。在开发过程中,推荐总是使用git pull --rebase 更新代码。

git pull --rebase

提交代码

# 暂存
git add <dir>

# 提交到本地仓库
git commit -m "<message>"

# 修改最后一次提交
git commit --amend

# 提交到remote
git push

追溯代码

由于commit-id一般不方便记忆,开发过程中在简单情况可以用~和^来追溯版本。

ref~表示第一个父级(等价ref~1),ref~2表示 第一个父级的第一个父级

ref^表示第一个父级(等价于ref^1),ref^2表示提交的第二个父级

在简单情况可以用ref~或^来追溯,复杂情况直接用commit-id会更方便。

合并代码

git merge相关

# 默认,快进合并
git merge 
# 非快进合并
git merge --no-ff 

git cherry-pick 相关

git cherry-pick:git cherry-pick 教程 - 阮一峰的网络日志

# 合并提交,-x 在提交信息末­尾追加­来源,-s 追加操作者签名。
git cherry­-pick -x <co­mmi­t>

# 合并多个连续­的提交­,左开右闭区间。
git cherry­-pick <co­mmi­t1>­..<­co­mmi­t2>

# 合并多个连续­的提交­,左闭右闭区间。
git cherry­-pick <co­mmi­t1>­^..<­co­mmi­t2>

打补丁

git提供两种打补丁方式,1:git diff 生成的UNIX标准补丁.diff文件,不带有commit记录 2. git format-patch 生成的git专用.patch文件,带有commit记录信息

可以参考:https://www.cnblogs.com/ArsenalfanInECNU/p/8931377.html

git format-patch

# 生成最近n次提交的补丁
git format-patch HEAD~n

git apply

git apply不会将commit message等打上去,打完patch后需要重新git add和git commit,相当于你改动的代码

git apply XXXX.patch

# 查看patch的情况
git apply --stat XXXX.patch

# 检查patch是否能够打上,如果没有任何输出,则说明无冲突,可以打上
git apply --check XXXX.patch

git am

git am会将patch的所有信息打上去,并且不用add、commit,因为他会应用commit上去,信息是patch上面的的author、message等等,不是打patch的。


# 打入补丁(会­生成提­交),­--k­eep-cr 防止回车符被­移除导­致打补丁失败,冲突时可使用 --reject 查看冲突。
git am --keep-cr XXXX.patch

# 添加-s或者--signoff,还可以把自己的名字添加为signed off by信息,作用是注明打patch的人是谁,因为有时打patch的人并不是patch的作者
git am --signoff XXXX.patch 

历史记录

# 查看与某个字­符串 ­str­ing­ 相关的改动,可用来查看某个函数相关的改动。
git log -S <st­rin­g>

# 查看一个文件­或目录­的历史­记录,­可用来查看某­个文件­是何时被删除的。
git log -- <pa­th>

Git 会在后台保存一个引用日志(reflog),引用日志只存在于本地仓库。每一次提交或改变分支,引用日志都会被更新。可以此恢复丢失的提交。

# 查看本地仓库 HEAD 指针的所有变­更,可­用于恢­复丢失的代码。
git reflog

# 追踪代码改动。实际开发过程中建议使用 Git 可视化工具。
git blame

调整历史记录

在开发过程中,很多情况我们都可能需要修订历史记录,eg:信息填错、某条记录代码有问题、某条记录代码太多想要拆分,在代码提交到远程仓库之前,我们可以随便在本地修改历史记录。

git没有修改历史记录的工具,但是可以通过变基命令来变基系列提交来达到修改历史记录的目的。

# 以交互方式重­新应用最近n次的提交,可­对提交进行修改,注意不要修改到已经推送到远程仓库的提交。
git rebase -i HEAD~n

git rebase -i 合并多个commit提交-Git-安卓笔记本

git 为我们提供了以下几个命令:

  • pick:保留该commit(缩写:p)
  • reword:保留该commit,但我需要修改该commit的注释(缩写:r)
  • edit:保留该commit, 但我要停下来修改该提交(不仅仅修改注释)(缩写:e)
  • squash:将该commit和前一个commit合并(缩写:s)
  • fixup:将该commit和前一个commit合并,但我不要保留该提交的注释信息(缩写:f)
  • exec:执行shell命令(缩写:x)
  • drop:我要丢弃该commit(缩写:d)

在编辑模式中,修改,最后保存。

例如我想把我写的这两个commit合并到一块:

git rebase -i HEAD~2

编辑当前合并之后的commit message

对多个本地commit合并完成。

贮藏改动

使用git stash命令保存和恢复进度_git stash用法-CSDN博客

https://www.cnblogs.com/zndxall/p/9586088.html

当你工作做一半的时候,你的代码已经有了一些改动,你可能需要切换到另一个分支干活,或更紧急的事情处理,这是你不想因为这个没做完的改动而commit。这时就可以git stash将代码贮藏。贮藏的代码保存在一个栈上,可以在任何时候重新应用。

或者是你在拉取代码时遇到冲突,你可以先git stash贮藏起来,那么就可以顺利拿到最新代码,在重新应用解决冲突。

git stash贮藏

贮藏文件的修改,请注意未跟踪untracked的不会贮藏,例如:新增的文件没有add的话,不会贮藏

使用 -u 也会贮藏未跟­踪(U­n­t­ra­­cke­­d)的文件。

# 跟踪改动Modified的文件,请注意untracked不会贮藏
git stash

# untracked也会贮藏
git stash -u

# 可以添加备注,可以方便查找
git stash save "save message"

列出所有贮藏的改动:

git stash list

应用stash:

请注意:

    1. git stash apply,不会在对应的栈中删除
    2. git stash pop 会应用最近的一次贮藏改动,并出栈
# 应用最近一次的 贮藏 改动
git stash apply

# 跟上shach@{n}指定对应记录
git stash apply stash@{n}

# 应用最近一次的贮藏的改动,并丢弃这条
git stash pop

丢弃贮藏

# 丢弃最近一次­贮藏的­改动,后面跟上 stash@{n} 可指定对应的记录
git stash drop

# 丢弃所有的贮藏改动
git stash clear

远程仓库Remote

克隆代码到本地仓库

git clone XXXX.git

管理远程

git remote作用:

1.git remote 不带参数,列出已经存在的远程分支

2.git remote -v | --verbose 列出详细信息,在每一个名字后面列出其远程url,此时, -v 选项(译注:此为 –verbose 的简写,取首字母),显示对应的克隆地址。

3.git remote add url 添加一个远程仓库

4、git remote rm name # 删除远程仓库
5、git remote rename old_name new_name # 修改仓库名

# 删除远程仓库分支emergent-fix
git push origin --delete emergent-fix

其他整理

1.解决git无法处理wsl虚拟机中的项目,

fatal: detected dubious ownership in repository at '//wsl.localhost/Ubuntu/home/wps/projects/ksogit/xfx'

To add an exception for this directory, call:

git config --global --add safe.directory "*"

2.设置git内部环境变量

~/.bashrc 中加入

例如我的

# 在windows中:C:\Program Files\JetBrains\GoLand 2023.3\bin
export PATH="/c/Program Files/JetBrains/GoLand 2023.3/bin:$PATH"

那么就可以在git当中使用goland64 . 用goland来打开当前文件夹作为项目了。

图形工具

tortoisegit:

tortoise git无法管理wsl下的库-CSDN博客

文件上的图标,可以反映出当前文件或者文件夹的状态.例如:

sourcetree:https://www.cnblogs.com/Can-daydayup/p/13128633.html

参考文档

  1. Git官方推荐书籍:Git - Book
  2. Learn Git Branching

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

上位机图像处理和嵌入式模块部署(视频处理vs图像处理)

【 声明&#xff1a;版权所有&#xff0c;欢迎转载&#xff0c;请勿用于商业用途。 联系信箱&#xff1a;feixiaoxing 163.com】 从目前发展的情况来看&#xff0c;视频处理会慢慢变成一种主流趋势。这里面的原因很多&#xff0c;比如说现在嵌入式soc的算力越来越强、获取图像的…

如何用gpt快速做好数据分析?

由于技术限制&#xff0c;目前InfinitePaper AI仅支持上传1份文件&#xff0c;且大小不超过10M。但是&#xff0c;在强大的代码解释器面前&#xff0c;这都是小问题。我们只需要将可能用到的文件打包成压缩文件上传即可&#xff0c;之后要求GPT直接解压就能正常完成后续需求。 …

Docker进阶篇-Docker网络

一、描述 1、docker不启动&#xff0c;默认网络情况 查看网卡情况使用&#xff0c;ifconfig或者ip addr ens33&#xff1a;本机网卡 lo&#xff1a;本机回环网络网卡 virbr0:在CentoS 7的安装过程中如果有选择相关虚拟化的的服务安装系统后&#xff0c;启动网卡时会发现 …

政安晨的机器学习笔记——示例演绎在TensorFlow中使用 CSV数据(基于Colab的Jupyter笔记)(1.5万字长文超详细)

本笔记提供了如何在 TensorFlow 中使用 CSV 数据的示例&#xff1a;用 tf.data 加载 CSV 数据。 其中包括两个主要部分&#xff1a; 从磁盘加载数据将数据预处理为适合训练的形式。 本笔记侧重于加载&#xff0c;并提供了一些关于预处理的快速示例。 设置 import pandas a…

2024美国大学生数学建模竞赛美赛B题matlab代码解析

2024美赛B题Searching for Submersibles搜索潜水器 因为一些不可抗力&#xff0c;下面仅展示部分代码&#xff08;很少部分部分&#xff09;和部分分析过程&#xff0c;其余代码看文末 Dthxlsread(C:\Users\Lenovo\Desktop\Ionian.xlsx); DpDth(:,3:5); dy0.0042; dx0.0042; …

【Spring实战】33 Spring Boot3 集成 Nacos 配置中心

文章目录 1. 配置中心定义2. 解决哪些问题3. 常用的配置中心4. 使用示例1&#xff09;没引入 Nacos 配置中心2&#xff09;引入依赖3&#xff09;配置Nacos连接信息4&#xff09;在 Nacos 上配置属性5&#xff09;在 Spring Boot 中使用配置6&#xff09;启动服务&验证7&am…

HiFT全参数微调新范式---逐层微调

论文链接: https://arxiv.org/abs/2401.15207 HiFT 是一个端到端的层级优化策略。目前论文的结果是原始混合精度的结果&#xff0c;目前最新进展已将混合精度进行了分层适配&#xff0c;微调7B模型的内存需求约为16.87G&#xff0c;13B模型约为31G(batch1,seq_length512) 背景…

Fluent的小bug处理:后处理截面显示存在漏洞

最近发现的Fluent的bug&#xff0c;关于后处理截面显示不完整的问题。 1 现象 在使用六面体核心类型单元&#xff08;包括四面体-六面体核心和多面体-六面体核心&#xff09;进行网格划分的时候&#xff0c;可能会在截面上不能完整捕捉单元形状及其分布状态&#xff0c;导致做…

后端——go系统学习笔记(不断更新中......)

数组 固定大小 初始化 arr1 : [3]int{1, 2, 3} arr2 : [...]int{1, 2, 3} var arr3 []int var arr4 [4]int切片 长度是动态的 初始化 arr[0:3] slice : []int{1,2,3} slice : make([]int, 10)len和cap len是获取切片、数组、字符串的长度——元素的个数cap是获取切片的容量—…

docker相关问题解决(file exists、not a directory

背景 以下环境为wsl file exists 缓存没删干净 docker-compose down -v not a directory flags: 0x5000: not a directory: unknown: Are you trying to mount a directory onto a file (or vice-versa)? 明明我确定报错指示的位置就是文件而不是文件夹...相当神奇的错误 …

【lesson2】定长内存池的实现

文章目录 介绍定长内存池的设计定长内存池的实现需要成员变量需要的成员函数定长内存池结构定长内存池Delete&#xff08;释放空间&#xff09;的实现定长内存池New&#xff08;申请空间&#xff09;的实现 定长内存池的实现完整版 介绍 作为程序员(C/C)我们知道申请内存使用的…

谷歌产品大更新:Bard可生成图像;文生音乐平台等5大免费功能

2月2日&#xff0c;谷歌在官网对生成式AI产品进行了大更新&#xff0c;包括类ChatGPT聊天助手Bard可以通过文本提示生成图像&#xff1b; 全新的文生音乐平台MusicFX&#xff1b;新的文生图像平台ImageFX&#xff1b;新的文本扩写平台TextFX&#xff1b;在谷歌地图中增加生成式…

Open3D 深度图像转点云

目录 一、算法原理1、算法过程2、主要函数3、算法源码二、代码实现三、结果展示1、深度图像2、点云四、测试数据

Python详细教程

一、Python简历 Python 是一个高层次的结合了解释性、编译性、互动性和面向对象的脚本语言。 Python 的设计具有很强的可读性&#xff0c;相比其他语言经常使用英文关键字&#xff0c;其他语言的一些标点符号&#xff0c;它具有比其他语言更有特色语法结构。 Python 是一种解…

客户端和服务端的简介

Client 和 Server 客户端&#xff08;Client&#xff09; 或称用户端&#xff0c;是指与服务器相对应&#xff0c;为客户提供本地服务的程序。除了一些只在本地运行的应用程序之外&#xff0c;一般安装在客户机上&#xff0c;需要与服务端互相配合运行。例如&#xff1a;下载 Q…

jvm基础篇之垃圾回收[3](垃圾回收器)

文章目录 分代GC代取划分原因垃圾回收器组合关系年轻代-Serial垃圾回收器老年代-SerialOld垃圾回收器年轻代-ParNew垃圾回收器老年代-CMS垃圾回收器年轻代-Parallel Scavenge垃圾回收器老年代-Parallel Old垃圾回收器 G1垃圾回收器G1内存结构G1回收方式年轻代回收混合回收FULL …

安全通信设置:使用 OpenSSL 为 Logstash 和 Filebeat 提供 SSL 证书

在为 Elasticsearch 采集数据时&#xff0c;我们经常使用到 Filebeat 及 Logstash。在我们之前的很多教程中&#xff0c;我们通常不为 Filebeat 和 Logstash 之前的通信做安全配置。 如何为 Filebeat 及 Logstash 直接建立安全的链接&#xff1f;这个在很多的情况下是非常有用的…

2024美赛A题七鳃鳗种群复杂系统动力学模型完整成品论文和代码

经过不懈的努力&#xff0c;2024美赛A题完整成品论文和代码已完成&#xff0c;代码为A题全部4问的代码&#xff0c;论文包括摘要、问题重述、问题分析、模型假设、符号说明、模型的建立和求解&#xff08;问题1七鳃鳗种群竞争模型的建立和求解、问题2种群优势劣势评估模型的建立…

很多人不看好造车新势力,我却坚信他们一定会成功

最近我国出现了很多新能源汽车品牌&#xff0c;除了理小蔚之外&#xff0c;最近爆火的华为与赛力斯合作的问界以及小米借用北汽生产的小米SU7汽车。可能是于大嘴和雷布斯营销过度了&#xff0c;引起了很多网民的质疑&#xff0c;更是引来了汽车大佬长安董事长的担忧。朱董事长说…

如何取消隐藏Excel中的行?这里提供详细步骤

取消隐藏Microsoft Excel电子表格中的所有行就像按下键盘快捷键或使用功能区上的按钮一样简单。我们将向你展示如何操作。 如何使用快捷方式取消隐藏Excel中的所有行 若要在电子表格中显示隐藏行&#xff0c;请使用Microsoft Excel启动电子表格。然后&#xff0c;访问包含隐藏…