随心玩玩(十)git

news2025/1/19 3:10:43

写在前面:研究生一年多了,一直浑浑噩噩的,在深度学习的泥潭挣扎了好久,终于走出了精神内耗的泥潭…好久没有写博客了,决定重新捡起来…记录一下学习吧~

之前写了一篇git的博客,【github 从0开始的基本操作到fork和pr项目】,感觉就是快速入门,没有掌握精髓,今天重新学习一下

感谢【GeekHour】在b站提供的免费视频教程

看了看了以前的博客有种梦回初始的感觉

优雅的分割线↓


文章目录

  • 初始化配置
  • 新建仓库
  • 工作区和文件状态
  • 添加和提交文件
  • 查看提交记录
  • reset 版本回退
  • diff 查看版本差异
  • 删除文件
  • .gitignore 忽略文件
  • 关联远程
  • GUI
  • 分支branch
  • 解决冲突
  • rebase变基
  • merge和rebase优缺点
  • 工作流 gitflow
  • GitHubflow

初始化配置

查看版本
git -v
配置全局用户名
git config --global user.name "likeghee"
配置全局邮箱
git config --global user.email likeghee@163.com
保存用户名和密码
git config --global credential.helper store
查看配置信息
git config --global credential.helper store

新建仓库

先在github创建仓库
然后用git clone远程仓库拉取
git clone

工作区和文件状态

git的本地数据管理分为三个区域
分别是工作区,暂存区和本地仓库

工作区:.git所在目录,我们实际操作的目录
暂存区:.git/index,用于临时存放即将提交修改的内容
本地仓库:.git/objects,Git存储代码和版本信息的主要位置

git add:从工作区提交到暂存区
git commit:从暂存区提到本地仓库

文件状态:
查看当前仓库的状态
git status
为跟踪:untrack,新创建还没有被git管理
未修改:unmodified,git管理但是文件内容没有发生变化
已修改:modified,git管理已经修改的文件但是还没有添加到暂存区中
已暂存:staged,已添加到暂存区中
在这里插入图片描述

添加和提交文件

创建文件
这里我创建了一个a.py,用git status查看当前仓库的状态
在这里插入图片描述

红色就是未被跟踪的状态,使用git add a.py添加到暂存区,再用用git status查看当前仓库的状态,现在的文件已经是绿色,表示现在这个文件已经被添加到了暂存区,等待被提交,同时bash还提示我们使用git restore --staged <file>...可以取消暂存
在这里插入图片描述
提交到本地仓库
git commit -m "第一次提交测试"
在这里插入图片描述

可以使用通配符提交文件
git add *.py
添加当前目录所有文件
git add .

交互式提交仓库
git commit
在这里插入图片描述
在第一行写下提交信息
在这里插入图片描述
:wq提交至仓库

查看提交记录

查看提交记录
git log
查看简洁的提交记录
git log --oneline

在这里插入图片描述

reset 版本回退

git reset --soft id:回退到某个版本,并且保留工作区和暂存区的所有内容
git reset --hard id:回退到某个版本,并且丢弃工作区和暂存区的所有内容
git reset --mixed id--mixed是默认参数,回退到某个版本,只保留工作区而丢弃暂存区内容
id使用git log --oneline查看
在这里插入图片描述

一般来说,当我们连续提交了多个版本,但是又觉得这些提交有没有太大的意义,可以合并成一个版本的时候,就可以通过–soft或者–mixed这两个参数回退之后再重新提交,使用--soft 可以节省一步git add的操作

一般谨慎使用--hard这个参数,工作区都删除了,那么就无法找回了

误操作可以使用git reflog查看操作的历史记录,找到误操作之前的版本号
再使用git reset --hard id回到之前版本即可

diff 查看版本差异

diff可以查看工作区、暂存区、本地仓库之间的差异
也可以查看不同版本之间的差异
或者两个分支之间的差异

开发的时候我们更多会使用GUI工具

我在a3.py添加了一行123
使用git diff查看修改内容,默认比较工作区和暂存区之间的内容

在这里插入图片描述
git会将文件的内容使用hash算法生成一个40位的hash值
e69de29..d800886就是hash值的前7位和后7位
100644 表示文件权限
红色表示删除,绿色表示添加

比较工作区和版本库之间的差异
git diff HEAD

比较工作区和版本库之间的差异
git diff --cached

比较两个版本之间的差异
git diff id1 id2

比较版本和当前版本之间的差异
git diff id1 HEAD

比较上个版本和当前版本之间的差异
git diff HEAD~ HEAD

比较上两个版本和当前版本之间的差异
git diff HEAD~2 HEAD

比较上个版本和当前版本中具体文件的差异
git diff HEAD~ HEAD a.txt

删除文件

删除文件
再用git add提交暂存区

这样有的人觉得太麻烦,可以使用
git rm
将上面的两步合并

只删除版本库的文件,保留工作区文件
git rm --cached

但是最后都是需要用git commit提交至版本库

.gitignore 忽略文件

应该忽略哪些文件?
系统或者软件自动生成的文件
编译生成的中间文件
运行过程中生成的日志文件、缓存文件、临时文件
涉及身份、密码、口令、密钥等敏感信息文件

.idea要不要提交到仓库里?我看了下这篇知乎文章

.idea目录下的文件中有包含隐私的内容(比如你的文件操作变动、用户词典、系统环境变量、数据库密码等等),所以我为了安全考虑就不提交到仓库了
在git项目的根目录下,添加一个 .gitignore 文件
在这里插入图片描述

.gitignore 文件中写上我们将要屏蔽的文件.idea/
注意文件夹格式是以/结尾的

.idea/

再用git status查看就屏蔽了这两个文件了
在这里插入图片描述

注意不会忽略doc下子目录下的.txt文件
doc/*.txt
如果要忽略可以使用
doc/**/.txt

关联远程

… or create a new repository on the command line

echo "# test" >> README.md
git init
git add README.md
git commit -m "first commit"
git branch -M main
git remote add origin https://github.com/yyz159756/test.git
git push -u origin main

… or push an existing repository from the command line

git remote add origin https://github.com/yyz159756/test.git
git branch -M main
git push -u origin main:main

GUI

https://git-scm.com/downloads/guis

推荐SourceTree
在这里插入图片描述

分支branch

创建一个dev分支
git branch dev

切换到dev分支
git switch dev

模拟一下dev的分支情况,现在main分支和dev分支已经分叉了,实际工作中这样情况是非常常见的,现在我们需要把dev分支合并到主线代码中
在这里插入图片描述

切换到main使用
git merge dev
将dev合并到main分支中
在这里插入图片描述

如果一个分支已经被合并到其他分支了,那么可以使用
git branch -d dev
来删除dev分支
在这里插入图片描述

解决冲突

我们创建一个feat分支,修改a.py
切换回main分支,我们也修改a.py
这样我们就有两个分支同时修改了a.py
在这里插入图片描述
我们在main分支尝试合并feat分支
git merge feat

就会出现conflict提示
在这里插入图片描述

使用git status查看冲突文件列表
在这里插入图片描述
git diff 查看具体的冲突的内容
在这里插入图片描述

=号上面的内容是main分支修改的内容
=号下面的内容是feat分支修改的内容

我们需要手动编辑这个文件
在这里插入图片描述
经过修改我们解决冲突

在这里插入图片描述
再进行git addgit commit
那么就自动完成了合并的过程
在这里插入图片描述

rebase变基

变基操作会找到当前两条分支的共同祖先,再把当前分支上从共同祖先到最新提交记录的所有提交移动到目标分支最新的提交的后面
变基到main,可以形象的表示成当前分支嫁接到main

切换dev,变基到main,那么就dev分支就会变基到dev
切换到main,变基到dev,那么main分支会变变基到dev

在这里插入图片描述

我们用之前学习的版本回退git rest来继续做实验

切换到dev,然后rebase

这时候dev分支就变基到了main上
在这里插入图片描述

merge和rebase优缺点

merge优点:不会破坏原分支的提交历史,方便回溯和查看
缺点:会产生额外提交节点,分支图复杂

rebase优点:不会新增额外的提交记录,形成线性历史,比较直观
缺点:改变提交历史,改变了当前分支branch out的节点,避免在共享分支上使用

工作流 gitflow

gitflow

main:只允许合并分支修改
hotfix:从main分支分离,修复完成后合并到main分支,一般会将hotfix分支删除
dev:从main分支分离,项目的核心分支
feat:从dev分支分离,用于开发新的功能
release:预发布分支,从dev分支分离,稳定后合并到主分支中,再将预发布分支删除

GitHubflow

只有main分支长期存在
1.git clone // 到本地
2.git checkout -b feat 切换至新分支feat
(相当于复制了remote的仓库到本地的xxx分支上
3.修改或者添加本地代码(部署在硬盘的源文件上)
4.git diff 查看自己对代码做出的改变
5.git add 上传更新后的代码至暂存区
6.git commit 可以将暂存区里更新后的代码更新到本地git
7.git push origin feat 将本地的featgit分支上传至github上的git


(如果在写自己的代码过程中发现远端GitHub上代码出现改变)
1.git checkout main 切换回main分支
2.git pull origin master(main) 将远端修改过的代码再更新到本地
3.git checkout xxx 回到xxx分支
4.git rebase main 我在xxx分支上,先把main移过来,然后根据我的commit来修改成新的内容
(中途可能会出现,rebase conflict -----》手动选择保留哪段代码)
5.git push -f origin xxx 把rebase后并且更新过的代码再push到远端github上
(-f —》强行)
6.原项目主人采用pull request 中的 squash and merge 合并所有不同的commit


远端完成更新后
1.git branch -d xxx 删除本地的git分支
2.git pull origin master 再把远端的最新代码拉至本地

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

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

相关文章

<蓝桥杯软件赛>零基础备赛20周--第8周第2讲--排序的应用

报名明年4月蓝桥杯软件赛的同学们&#xff0c;如果你是大一零基础&#xff0c;目前懵懂中&#xff0c;不知该怎么办&#xff0c;可以看看本博客系列&#xff1a;备赛20周合集 20周的完整安排请点击&#xff1a;20周计划 每周发1个博客&#xff0c;共20周&#xff08;读者可以按…

WakaTime一个用于跟踪和分析编程时间的工具

WakaTime是一个用于跟踪和分析编程时间的工具&#xff0c;它可以集成到各种代码编辑器和集成开发环境中&#xff0c;例如Visual Studio Code、Sublime Text、PyCharm等。它可以帮助开发人员了解他们花费在不同项目和编程语言上的时间&#xff0c;以及他们的编码习惯和生产力。 …

【Tkinter 入门教程】

【Tkinter 入门教程】 1. Tkinter库的简介&#xff1a;1.1 GUI编程1.2 Tkinter的定位 2. Hello word! 程序起飞2.1 第⼀个程序2.2 字体颜色主题 3. 组件讲解3.1 tkinter 的核⼼组件3.2 组件的使⽤3.3 标签Label3.3.1 标签显示内容3.3.2 多标签的应⽤程序3.3.3 总结 3.4 按钮but…

【动态规划】LeetCode-面试题 17.16. 按摩师

&#x1f388;算法那些事专栏说明&#xff1a;这是一个记录刷题日常的专栏&#xff0c;每个文章标题前都会写明这道题使用的算法。专栏每日计划至少更新1道题目&#xff0c;在这立下Flag&#x1f6a9; &#x1f3e0;个人主页&#xff1a;Jammingpro &#x1f4d5;专栏链接&…

类和对象——(4)特殊的成员函数

归纳编程学习的感悟&#xff0c; 记录奋斗路上的点滴&#xff0c; 希望能帮到一样刻苦的你&#xff01; 如有不足欢迎指正&#xff01; 共同学习交流&#xff01; &#x1f30e;欢迎各位→点赞 &#x1f44d; 收藏⭐ 留言​&#x1f4dd; 一个人不是在逆境中成长&#xff0c;就…

强推六款满分AI写作工具,需要自取

&#x1f517; 运行环境&#xff1a;ChatGPT &#x1f6a9; 撰写作者&#xff1a;左手の明天 &#x1f947; 精选专栏&#xff1a;《python》 &#x1f525; 推荐专栏&#xff1a;《算法研究》 &#x1f510;#### 防伪水印——左手の明天 ####&#x1f510; &#x1f497; 大家…

vite脚手架,手写实现配置动态生成路由

参考文档 vite的glob-import vue路由配置基本都是重复的代码&#xff0c;每次都写一遍挺难受&#xff0c;加个页面就带配置下路由 那就利用 vite 的 文件系统处理啊 先看实现效果 1. 考虑怎么约定路由&#xff0c;即一个文件夹下&#xff0c;又有组件&#xff0c;又有页面&am…

SSM项目实战-登录验证成功并路由到首页面,Vue3+Vite+Axios+Element-Plus技术

1、util/request.js import axios from "axios";let request axios.create({baseURL: "http://localhost:8080",timeout: 50000 });export default request 2、api/sysUser.js import request from "../util/request.js";export const login (…

Presto:基于内存的OLAP查询引擎

Presto查询引擎 1、Presto概述1.1、Presto背景1.2、什么是Presto1.3、Presto的特性2、Presto架构2.1、Presto的两类服务器2.2、Presto基本概念2.3、Presto数据模型3、Presto查询过程3.1、Presto执行原理3.2、Presto与Hive3.3、Presto与Impala3.4、PrestoDB与PrestoSQL4、Presto…

主键虽两个字,但含义丰富;创建新表,Access会自动创建主键,但也可以手动设置

主键是一种特殊类型的索引字段&#xff0c;用于唯一标识表中的每个记录或行。每个主键值必须是表中唯一一个此类主键值。创建新表时&#xff0c;Access会自动创建具有字段名ID和自动编号数据类型的主键。 你需要了解的有关主键的一些信息 一个表只能有一个主键。 主键字段中…

【Python】tensorflow学习的个人纪录(3)

sess tf.Session()actor Actor(sess, n_featuresN_S, lrLR_A, action_bound[-A_BOUND, A_BOUND])步进&#xff1a;

1+x网络系统建设与运维(中级)-练习3

一.设备命名 AR1 [Huawei]sysn AR1 [AR1] 同理可得&#xff0c;所有设备的命名如上图所示 二.VLAN LSW1 [LSW1]vlan 10 [LSW1-vlan10]q [LSW1]int g0/0/1 [LSW1-GigabitEthernet0/0/1]port link-type access [LSW1-GigabitEthernet0/0/1]port default vlan 10 [LSW1-GigabitEt…

[ffmpeg] aac 音频编码

aac 介绍 aac 简单说就是音频的一种压缩编码器&#xff0c;相同音质下压缩比 mp3好&#xff0c;目前比较常用。 aac 编码支持的格式 aac 支持的 sample_fmts: 8 aac 支持的 samplerates: 96000 88200 64000 48000 44100 32000 24000 22050 16000 12000 11025 8000 7350 通…

U盘不仅能在电脑上使用,在手机上也可使用,包括安卓和苹果手机,但苹果的较特殊

许多最好的安卓手机都使用USB-C端口在电脑上充电和来回传输文件,但如果你需要给老板发电子邮件的文件放在闪存驱动器或全尺寸SD卡上呢? 幸运的是,使用廉价的适配器电缆,你可以将USB加密狗或读卡器直接连接到手机上。你甚至可以直接使用USB-C闪存驱动器,以实现更轻松的过程…

带头双向循环链表:一种高效的数据结构

&#x1f493; 博客主页&#xff1a;江池俊的博客⏩ 收录专栏&#xff1a;数据结构探索&#x1f449;专栏推荐&#xff1a;✅cpolar ✅C语言进阶之路&#x1f4bb;代码仓库&#xff1a;江池俊的代码仓库&#x1f525;编译环境&#xff1a;Visual Studio 2022&#x1f389;欢迎大…

Unity DOTS《群体战斗弹幕游戏》核心技术分析之3D角色动画

最近DOTS发布了正式的版本, 我们来分享现在流行基于群体战斗的弹幕类游戏&#xff0c;实现的核心原理。今天给大家介绍大规模战斗群体3D角色的动画如何来实现。 DOTS 对角色动画支持的局限性 截止到Unity DOTS发布的版本1.0.16,目前还是无法很好的支持3D角色动画。在DOTS 的b…

【Python】tensorflow学习的个人纪录(2)

actor.learn(s, a, td_error)def learn(self, s, a, td):s s[np.newaxis, :]feed_dict {self.s: s, self.a: a, self.td_error: td}_, exp_v self.sess.run([self.train_op, self.exp_v], feed_dict)return exp_v输入变量的数值&#xff1a; 步进&#xff1a; []---->[…

算法设计与实现--动态规划篇

什么是动态规划算法 动态规划算法是一种求解复杂问题的方法&#xff0c;通过将原问题分解为相对简单的子问题来求解。其基本思想是将待求解的问题分解为若干个子问题&#xff08;阶段&#xff09;&#xff0c;按顺序求解子阶段&#xff0c;前一子问题的解&#xff0c;为后一子…

割裂式“多渠道”不是真正的全渠道!浅析全渠道零售和DTC在理念上的不谋而合|徐礼昭

图文&#xff1a;徐礼昭 全渠道零售概念解析 全渠道零售概念由来已久&#xff0c;单纯从业务经营角度&#xff0c;一个品牌在线上线下多个渠道铺货卖货&#xff0c;只能说是多渠道零售&#xff0c;而不是全渠道零售。商派市场负责人徐礼昭认为&#xff0c;品牌企业应该从消费者…

前后端分离部署https

引用&#xff1a;https://blog.csdn.net/weixin_35676679/article/details/127841598 前后端部署&#xff0c;&#xff0c;一般用的是nginx和java&#xff0c;&#xff0c;&#xff0c; 下载SSL证书&#xff1a; java配置https 将证书配置到springboot中 server:port: 544…