笔记:Git学习之应用场景和使用经验

目标:整理Git工具的应用场景和使用经验

一、开发环境

Git是代码版本控制工具;Github是代码托管平台。

工具组合:VSCode + Git

需要安装的软件:vscode、Git

其中vscode需要安装的插件:GitLens、Git History

二、应用场景

工作场景:嵌入式开发,本地使用

三、使用总结

基础操作,参考廖雪峰的Git教程

Git教程 - 廖雪峰的官方网站

Git 基本工作流程

3.1 版本管理
3.1.1 更改提交

git commit

使用 git commit 将当前工作目录的更改保存到本地代码库。

每次提交(commit)都会创建一个新的提交对象,

避免将无关或不相关的修改混合在一起提交。

3.1.2 版本回退

两种方式:reset、revert

git reset

通过改变HEAD和分支指针指向的方式,进行版本回退,

该操作之后的提交记录不会被保留,并且不会创建新的提交;

git revert

通过创建一个新提交的方式来撤销某次操作,该操作之前和之后的提交记录都会被保留,

并且会将该撤销操作作为最新的提交;

在个人开发上,建议使用reset;但在团队开发中建议使用revert,

特别是公共的分支(比如master),这样能够完整保留提交历史,方便回溯。

3.2 分支管理

一个分支代表一条独立的开发线,使用分支可以从开发主线上分离开来,

不影响主线的同时继续工作。

注:未被放入代码库的文件会在分支切换时被抛弃,造成严重后果。

3.2.1 分支切换

git switch

使用git switch <branch_name> 来切换到指定的分支。

3.2.2 分支合并

两种方式:merge、rebase

相同点:都是从一个分支合并到当前分支。

注意:无论选择哪种方式,都应该谨慎处理可能产生的冲突,

并确保在操作前备份代码或创建临时分支以防意外。

git merge

自动创建一个新的commit,如果遇到冲突,仅需要修改后重新commit。

方式:git merge会将目标分支的提交历史合并到当前分支,形成一个新的合并提交。

这种方式被称为"合并提交"或"三方合并",因为它保留了每个分支的独立提交历史。

结果:合并后的提交历史会包含源分支和目标分支的所有共同提交以及合并提交。

场景:适用于合并公共分支、团队开发时的代码集成,或者希望保留分支独立性的情况。

合并稳定的公共分支,如主分支或发布分支。多人协作开发时,将各自的特性分支合并到开发分支。

git rebase

找公共的节点,直接合并之前commit历史,得到简洁的分支发展历史,去掉了merge commit。

方式:git rebase会将当前分支的提交"移动"到目标分支的最新提交之后,

然后将目标分支的提交历史应用到当前分支。这种方式被称为"变基",因为它改变了提交的基点。

结果:合并后的提交历史是线性的,没有合并提交,看起来更加整洁。

但是原始分支的提交历史会被修改,可能会导致冲突。

场景:适用于想要保持线性提交历史、清晰的提交记录,并希望将自己的提交"放到"目标分支上进行整合的情况。

最好不要在公共分支上使用rebase,如果前后基本上不会有别人改动你的分支,那么推荐rebase。

总结来说,在单人本地多分支开发中,使用变基操作来修复bug并更新所有分支是可行的,

可以确保所有分支都包含了最新的修复,并保持提交历史的线性和清晰。

但是仍然建议在执行变基操作之前,仔细考虑其可能带来的影响,并确保备份了代码。

3.3 标签管理

标签也是版本库的一个快照。

发布版本时,通常在版本库中打个标签(tag),则唯一确定打标签时刻的版本。

切换到某个标签,则相当于把打标签时刻的历史版本取出。

注意:标签总是和某commit挂钩。若该commit既出现在master分支,

又出现在dev分支,则在这两个分支上都可看到此标签。

3.3.1 标签切换

使用git checkout <tagname>可将git仓库的HEAD指针指向标签所在的提交,

如:git checkout v1.0

3.4 开发管理

涉及到多人协作,如果没有清晰的流程和规划,每个人都提交一堆杂乱无章的 commit,

项目很快就会变得难以协调和维护。Git 版本管理同样需要一个清晰的流程和规范。

3.4.1 Git flow

Git flow的优点是清晰可控,缺点是相对复杂,需要同时维护两个长期分支。

该模式是基于"版本发布"的,目标是一段时间以后产出一个新版本。

长期分支:主分支master、开发分支develop。

前者用于存放对外发布的版本,任何时候在这个分支拿到的,都是稳定的分布版;

后者用于日常开发,存放最新的开发版。

短期分支:功能分支(feature branch)、补丁分支(hotfix branch)、发布分支(release branch)。

3.4.2 Github flow

Github flow 是Git flow的简化版,专门配合"持续发布"。

3.4.3 Gitlab flow

Gitlab flow 是 Git flow 与 Github flow 的综合。

它吸取两者的优点,既有适应不同开发环境的弹性,又有单一主分支的简单和便利。

四、经验总结
4.1 文件未修改,但出现在工作区

修改文件权限可修复该异常。

项目修改:git config core.filemode false
全局修改:git config --global core.filemode false

如果在Linux和windows之间传递代码,可能出现该异常。

修改换行符转换设置,可修复该异常。

git config --global core.autocrlf false
git config --global core.filemode false
git config --global core.safecrlf true

4.2 如何使.gitignore中新增设置对之前的文件生效
$ git rm -r --cached .                #清除缓存 -r 表示递归删除(如果有文件夹的话) . 表示所有文件
$ git add .                           #重新trace file
$ git commit -m "update .gitignore"   #提交和注释$ git status --ignored                #查看状态,包括忽略的文件
4.3 导出历史提交记录

git log --pretty=format:"%ai , %an: %s" >> ./commit.log

在项目根目录下执行命令,导出 git 提交记录到桌面git log --pretty=format:"%ai , %an: %s" --since="100 day ago" >> ./commit.log
如果想导出某些提交者的提交记录,可以用grep过滤,比如我想导出zen这个人在项目中的提交记录:git log --pretty=format:"%ai , %an: %s" --since="126 day ago" | grep "zen" >> ./commit.log
当然也可以导出成 Excel 文件git log --date=iso --pretty=format:'"%h","%an","%ad","%s"' >> ./commit.log%ai: 表示提交的时间,格式为 ISO 8601 标准的时间(例如 2024-04-16 14:30:00)。
%an: 表示提交者的名字。
%s: 表示提交时填写的概要或简短描述。
选项说明

-p

按补丁格式显示每个提交引入的差异。

--stat

显示每次提交的文件修改统计信息。

--shortstat

只显示 --stat 中最后的行数修改添加移除统计。

--name-only

仅在提交信息后显示已修改的文件清单。

--name-status

显示新增、修改、删除的文件清单。

--abbrev-commit

仅显示 SHA-1 校验和所有 40 个字符中的前几个字符。

--relative-date

使用较短的相对时间而不是完整格式显示日期(比如“2 weeks ago”)。

--graph

在日志旁以 ASCII 图形显示分支与合并历史。

--pretty

使用其他格式显示历史提交信息。可用的选项包括 oneline、short、full、fuller 和 format(用来定义自己的格式)。

--oneline

--pretty=oneline --abbrev-commit 合用的简写。

选项说明

%H

提交的完整哈希值

%h

提交的简写哈希值

%T

树的完整哈希值

%t

树的简写哈希值

%P

父提交的完整哈希值

%p

父提交的简写哈希值

%an

作者名字

%ae

作者的电子邮件地址

%ad

作者修订日期(可以用 --date=选项 来定制格式)

%ar

作者修订日期,按多久以前的方式显示

%cn

提交者的名字

%ce

提交者的电子邮件地址

%cd

提交日期

%cr

提交日期(距今多长时间)

%s

提交说明

%ai表示提交的时间,格式为 ISO 8601 标准的时间

资料整理自网络

Git 历史提交日志导出到文件中 | 张益铭的博客 (zhangyiming748.github.io)

Git - 查看提交历史 (git-scm.com)

git日志导出命令 - xh_Blog - 博客园 (cnblogs.com)

Git 教程|极客教程 (geek-docs.com)

Git 历史提交日志导出到文件中_eclipse导出git提交记录-CSDN博客

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

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

相关文章

仓库货物管理系统

摘 要 随着信息技术的迅猛发展&#xff0c;大数据已经成为推动各行各业变革的重要力量。特别是在物流仓储领域&#xff0c;大数据技术的应用不仅能够显著提升仓库货物管理的效率&#xff0c;还能够优化库存管理、减少成本、提高客户满意度。因此&#xff0c;基于大数据的仓库货…

webstorm 高效查看不同分支差异 摒弃你的git diff手动操作

背景 每次代码冲突或者版本发生异常时&#xff0c;排查不同版本时就是一个头大的问题&#xff0c;头大的点在于用 vscode 的 git diff 一点点地排查和比较&#xff0c;耗时耗力&#xff0c;版面展不开&#xff0c;commit 差异看不出来&#xff0c;每个页面的代码不同也不能快速…

2007-2023年36家商业银行绿色信贷、期末贷款总额、银行总资产等相关指标数据(2023年无缺失)

2007-2023年36家商业银行绿色信贷数据&#xff08;2023年无缺失&#xff09; 1.时间&#xff1a;2007-2023年&#xff0c;2023年无缺失 2.来源&#xff1a;银行年报和社会责任报告 3.指标:绿色信贷余额、期末贷款总额、绿色信贷比率、总资产收益率、流动性比率、拨备覆盖率、…

2002-2022年各省老年人口抚养比(人口抽样调查)数据

2002-2022年各省老年人口抚养比(人口抽样调查)数据 1、时间&#xff1a;2002-2022年 2、指标&#xff1a;老年人口抚养比 3、来源&#xff1a;国家统计局、统计年鉴 4、范围&#xff1a;31省&#xff0c; 5、缺失情况&#xff1a;无缺失&#xff0c;其中2010年的值取2009、…

华为 eNSP 模拟器 配置RIP实例 动态路由协议

1 实验拓扑 2 配置路由器 #R1 Huawei>sys [Huawei]sysname R1 [R1]interface GigabitEthernet 0/0/0 [R1-GigabitEthernet0/0/0]ip address 192.168.1.1 255.255.255.0 [R1-GigabitEthernet0/0/0]qu [R1]rip [R1-rip-1]network 192.168.1.0 [R1-rip-1]version 2 [R1-rip-…

ffmpeg在powershell和ubuntu终端下的不同格式

在win10下的powershell中&#xff0c;如果想运行一个exe文件&#xff0c;就不能再像cmd命令行一样用名字来直接运行了&#xff0c;否则会提示格式不对。 正确的做法是&#xff1a; . \ffmpeg.exe -re -i video-test.mpr -rtsp_transport tcp -vcodec h264 -f rtsp rtsp://您的…

MySQL 9.0 发布了!

从昨晚开始&#xff0c;在DBA群里大家就在讨论MySQL 9.0发布的事情&#xff0c;但是Release Note和官方文档都没有更新&#xff0c;所以今天早上一上班就赶紧瞅了下具体更新了哪些内容&#xff1f; 整体看来&#xff0c;基本没什么创新。下面是9.0新增或废弃的一些特性。 &…

“不喝鸡汤 不诉离殇”华火电燃灶用实力引领烹饪灶具发展

在这个快节奏的时代&#xff0c;我们常常被各种厨房电器的鸡汤所包围&#xff0c;并悄悄的告诉我们厨房生活是美好与温暖的&#xff0c;但面对现实中的挑战与困难时&#xff0c;常常表现出选择性失明&#xff1b;那些隐藏在传统厨房烹饪环境下的危机&#xff0c;就像是慢性的毒…

Java AI+若依框架项目开发 RuoYi-Vue(SpringBoot + Vue)

1.诺依的版本 本次选择RuoYI-Vue框架进行讲解 官网地址&#xff1a;RuoYi-Vue: &#x1f389; 基于SpringBoot&#xff0c;Spring Security&#xff0c;JWT&#xff0c;Vue & Element 的前后端分离权限管理系统&#xff0c;同时提供了 Vue3 的版本 (gitee.com) 2.搭建后端…

vue中使用 json编辑器

<template><div class"stringTest"><vue-json-editorv-model"vstringData" //编辑器中的内容:showBtns"false" // 保存按钮mode"code"lang"zh":expanded-on-start"true"json-change&quo…

5.Android逆向协议-初识HTTP和HTTPS协议

免责声明&#xff1a;内容仅供学习参考&#xff0c;请合法利用知识&#xff0c;禁止进行违法犯罪活动&#xff01; 内容参考于&#xff1a;微尘网校 上一个内容&#xff1a;4.Android逆向协议-详解二次打包失败解决方案 从现在开始正式进入协议分析了。 首先客户端与服务端之…

tkinter拖入txt文本并显示

tkinter拖入txt文本并显示 效果代码 效果 代码 import tkinter as tk from tkinter import scrolledtext from tkinterdnd2 import DND_FILES, TkinterDnDdef drop(event):file_path event.data.strip({})if file_path.endswith(.txt):with open(file_path, r, encodingutf-8…

Seatunnel本地模式快速测验

前言 SeaTunnel&#xff08;先前称为WaterDrop&#xff09;是一个分布式、高性能、易于扩展的数据集成平台&#xff0c;旨在实现海量数据的同步和转换。它支持多种数据处理引擎&#xff0c;包括Apache Spark和Apache Flink&#xff0c;并在某个版本中引入了自主研发的Zeta引擎…

Django学习第二天

启动项目命令 python manage.py runserver 动态获取当前时间 javascript实现数据动态更新代码 <script>setInterval(function() {var currentTimeElement document.getElementById(current-time);var currentTime new Date();currentTimeElement.textContent Curren…

经典的卷积神经网络模型 - ResNet

经典的卷积神经网络模型 - ResNet flyfish 2015年&#xff0c;何恺明&#xff08;Kaiming He&#xff09;等人在论文《Deep Residual Learning for Image Recognition》中提出了ResNet&#xff08;Residual Network&#xff0c;残差网络&#xff09;。在当时&#xff0c;随着…

【List】判断集合相等、集合拷贝

【List】判断集合相等、集合拷贝 【一】判断集合是否相等【1】☆使用list中的containAll【2】使用for循环遍历contains方法【3】将list先排序再转为String进行比较【4】使用list.retainAll()方法【5】使用MD5加密方式【6】转换为Java8中的新特性steam流再进行排序来进行比较 【…

AI数字人直播源码出售价格公布!

随着数字人行业的兴起&#xff0c;以数字人直播为代表的应用场景逐渐成为人们日常生活中不可分割的一部分&#xff0c;再加上艾媒研究数据显示&#xff0c;超五成以上的被调查群体的企业使用过虚拟人技术&#xff0c;超三成被调查群体的企业计划使用虚拟人技术等结论的公布&…

python-图像模糊处理(赛氪OJ)

[题目描述] 给定 n 行 m 列的图像各像素点的灰度值&#xff0c;要求用如下方法对其进行模糊化处理&#xff1a; 1. 四周最外侧的像素点灰度值不变。 2. 中间各像素点新灰度值为该像素点及其上下左右相邻四个像素点原灰度值的平均&#xff08;四舍五入&#xff09;输入&#xff…

【C语言】inline 关键字

在C语言中&#xff0c;inline关键字用于建议编译器对函数进行内联展开&#xff0c;而不是像普通函数一样调用。内联函数的目的是减少函数调用的开销&#xff0c;特别是对于简单的、频繁调用的函数。 内联函数的定义和使用 定义内联函数 要定义一个内联函数&#xff0c;需要在…

《代号鸢》国服,能否推动国乙市场重新洗牌?

灵犀互娱《如鸢》顺利拿到版号&#xff0c;再次搅浑了国乙市场这潭水。 六月份游戏版号审批公布后&#xff0c;灵犀互娱运营的《如鸢》引起了关注&#xff0c;这个与《代号鸢》原名《三国志如鸢》雷同的名字&#xff0c;竟然让《代号鸢》玩家大面积破防了。 其实目前关于《如…