论文解读:Self-Prompt Mechanism for Few-Shot Image Recognition

news2025/1/23 2:15:28

文章汇总

存在的问题

由于提示文本和图像特征之间固有的模态差异,常规的提示方法的性能受到限制。

动机

让视觉信息自己给自己提示

解决办法

SPM涉及到图像编码器跨空间和通道维度产生的固有语义特征的系统选择,从而产生自提示信息。随后,在将这种自提示信息反向传播到神经网络的更深层后,它有效地引导网络学习和适应新样本。

流程解读

作者的想法很简单,常规的方法都是用文本来指导Image Encoder,如图(a),但是由于提示文本和图像特征之间天然存在的模态gap,所以作者打算直接放弃文本的提示,让视觉自己给自己提示(单模态,图b)
image.png
如下图所示,作者只在最后的三层transformer block加入视觉自提示
image.png
作者的工作可以分为以下的三个部分
Self-Prompt Generation and Projection
图像的特征 F ∈ R N × D F\in R^{N\times D} FRN×D,可学习的空间提示向量 s ∈ R D s \in R^D sRD,可学习矩阵 C ∈ R N × D C\in R^{N\times D} CRN×D
m = N o r m ( F ) × N o r m ( s ) m =Norm(F) \times Norm(s) m=Norm(F)×Norm(s)
image.png
image.png
image.png
最终得到提示信息 F c F_c Fc
Self-Prompt Projection.
对提示信息 F c F_c Fc简单地做了一层投影得到了提示信息 P P P
image.png
Self-Prompt Attention.
让获得的提示信息 P P P再次加入transformer 快的Self-attention,所以我们在上图中也可以看到最后三层注意力机制跟之前的不一样,作者把他成为了 Self-Prompt Attention(“绿色那块”)
image.png

摘要

少样本学习提出了一个巨大的挑战,因为它需要基于有限的示例集有效地识别新类。最近的研究试图通过利用外部文本提示来调整视觉特征,以解决罕见样本的挑战。然而,**由于提示文本和图像特征之间固有的模态差异,这些方法的性能受到限制。我们提出了一种新的自提示机制(SPM)来根据未知数据自适应地调整神经网络,而不是纯粹地利用文本生成的外部语义信息来指导图像编码器的训练。具体来说,SPM涉及到图像编码器跨空间和通道维度产生的固有语义特征的系统选择,从而产生自提示信息。随后,在将这种自提示信息反向传播到神经网络的更深层后,它有效地引导网络学习和适应新样本。**同时,我们提出了一种新的参数高效调谐方法,**该方法只微调与自提示相关的参数(提示不超过总参数的2%),并将额外的可学习参数作为自提示的结合,通过冻结编码器权重来确保先验知识的保留。**因此,我们的方法非常适合于在有限的标记数据约束下需要信息保留和网络参数自适应调整的少样本识别任务。大量的实验表明,在标准的单域和跨域少样本识别数据集上,所提出的SPM分别在5-way 1-shot和5-way 5-shot设置下是有效的。我们的代码可在https://github.com/codeshop715/SPM上获得。

介绍

尽管深度学习在计算机视觉方面取得了重大进展,但它通常依赖于大量标记样本,这偏离了人类的学习过程。少样本学习(Finn, Abbeel, and Levine 2017;Munkhdalai等人2018;Antoniou, Edwards, and Storkey 2018)旨在弥合人类智能和机器学习之间的差距,通过解决从有限数量的标记训练数据中学习并推广到未见数据的挑战。少样本图像识别确实是少镜头学习算法领域的一个广泛的研究课题。少样本图像识别的目标是开发能够有效适应在有限样本数据下识别和分类未见类的模型。这项任务特别具有挑战性,因为它需要从一些标记数据中学习判别特征(Zhang et al 2022;Afrasiyabi et al 2022)。
由于新类别中标记样本的稀缺性,一种简单的方法是利用其他模式的信息作为辅助指导。最近,随着CLIP模型的引入(Radford et al 2021),一系列文本基于语义提示的方法(Chen et al . 2023;Zhu等2023;Jeong等人2023)已经出现,以指导视觉模块的训练。如图1 (a)所示,这些方法通常遵循CLIP的训练范式,分别使用文本编码器和图像编码器,基于文本嵌入生成判别图像特征。尽管基于文本的语义提示方法在短时学习领域取得了显著的成功,但大多数方法都存在以下问题。首先,语义提示依赖于生成的或手动编写的文本信息。尽管BERT (Devlin et al . 2019)和GPT (Radford et al . 2019)等大型语言模型(2018)可以从类名中提取丰富的文本信息,但同一类的文本描述的多样性导致生成的语义提示不准确。其次,基于文本的提示方法需要额外的文本编码器从文本信息中提取特征,导致额外的计算开销。第三,由于网络生成的文本和视觉特征不一致,文本和图像模态不同导致的信息缺口限制了文本特征为视觉特征学习提供最佳外部语义提示的有效性
image.png
图1:少样本图像识别的语义提示和自提示机制。(a):语义提示方法需要额外的文本信息和文本编码器来生成外部提示。(b):我们提出的自提示机制不需要额外的信息,只需要微调少量的参数就可以从图像编码器的固有语义信息中生成提示。
为了解决上述三个问题,受人类认知过程的启发(LEE 2002;Yu and Dayan 2004;Baifeng, Trevor, and Xin 2023)和人类元认知能力(Salles et al 2016),我们提出了一种新的自提示机制来指导视觉网络的训练。直觉上,人类具有元认知能力,可以根据过去的经验进行总结,并在遇到类似的问题或任务时提供自我提示(Fleming and Dolan 2012),允许他们修改自己的策略或行动方向,以便明确地与任务的目标保持一致。我们提出了一种新的方案,通过将自我提示机制应用于少样本学习过程来利用这种人类机制,如图1 (b)所示。具体而言,学习过程的指导是通过自上而下的方法实现的。我们对图像编码器的深层特征进行空间和通道选择,生成未见类或域的内在自提示信息,然后将生成的提示信息传回网络的深层,对特征提取过程进行自适应调整。通过提示自注意的计算过程,我们提出的自提示机制可以指导图像编码器的训练,从未见数据中提取判别特征。
此外,由于不同的看不见的类或领域具有不同的特征需求(Li, Liu, and Bilen 2022),因此网络必须具有一种通用且高效的自适应机制,能够有效处理看不见的类或领域的显著不同的语义特征。同时,当面对只有有限数量的标记数据的未见过的类或领域时,网络应该具有参数效率来调整自适应参数。为了解决这些挑战,我们提出了一种新的参数高效调优方法,该方法根据未见数据专门微调与自提示相关的参数,需要调整的参数不超过总网络参数的2%。因此,该方法还以冻结编码器权值的形式保证了先验知识的保留,特别适用于数据可用性有限的情况。同时,本文提出的方法为单域和跨域场景下的少样本图像识别任务提供了统一的自适应方法。我们的主要贡献可以概括如下:
•我们提出了一种新的自提示机制,用于少样本图像识别。该机制受人类认知过程的启发,旨在根据自我提示自适应调整网络以学习判别特征。
•我们设计了一种跨空间和通道维度的特征选择策略,以熟练地生成内在的自我提示信息,这些信息被用来指导自我注意计算。
•我们提出了一种新的参数高效调谐方法,该方法专门微调与自提示相关的参数(提示不超过总参数的2%),并将额外的可学习参数作为自提示的结合,确保通过冻结编码器权重来保留先验知识。
•我们在单域和跨域基准数据集(包括Mini-ImageNet, CIFAIR-FS和CDFSL)上评估了我们提出的少样本图像识别(简称SPM)的自提示机制。SPM取得了令人满意的结果,将最先进的1-shot和5-shot识别准确率平均分别提高了1.97%和1.45%。此外,烧蚀实验验证了所提出的特征选择策略和参数高效调谐方案的有效性。

相关的工作

少样本图像识别

少样本图像识别是少样本学习领域的一个重要分支。与普通识别任务不同,少样本图像识别任务涉及训练集和测试集之间的任务分配转移。通常,少样本识别任务可以分为两种不同的场景。第一种类型是在单域场景中,在训练集和测试集之间存在类别转移。在这种情况下有两种主要的学习方法,基于优化和基于参数。例如,作为基于优化方法的代表,MAML (Finn, Abbeel, and Levine 2017)及其变体(Sun et al 2019)旨在学习熟练的模型初始化,能够在有限数量的优化步骤内快速适应新类。或者,基于度量的方法旨在在适当的特征空间中表示样本,然后计算查询与一组支持示例的质心之间的距离(Vinyals等人2016;Hu et al . 2022;Afrasiyabi et al 2022)。第二种类型涉及跨域场景,与单域场景相比,它更具挑战性。除了类别转移之外,训练和测试集之间还存在领域转移。这类任务主要通过自适应调整网络参数来处理(Luo, Xu, and Xu 2022;赵、张、田2023;Yi et al . 2023)。与上述方法相比,我们提出了一种自提示机制来自适应地生成适合于未见过的类或域的特征。该方法不仅适用于单域场景下的少样本图像识别任务,也适用于跨域场景下的图像识别任务。

提示学习

提示学习(Liu et al . 2023)已经成为适应计算机视觉领域Transformer模型的一种高效技术。通过将一组可学习的参数合并到预训练模型的输入和中间表示中,Transformer可以适应特定的任务和领域。近期作品(Lester, Al-Rfou和Constant 2021;李梁2021;Liu et al . 2021)提出将提示视为特定类别的连续向量,并在微调期间通过梯度直接优化它们。这些研究强调了利用Transformer的内在能力在广泛的计算机视觉任务中增强适应方法的潜力。同时,VPT (Jia et al 2022)在Transformer的每一层引入了可学习的令牌,从而实现了与patch和class token的交互。这些可学习标记和分类器头部共同优化,实现有效的自适应。此外,(Chen et al . 2023)采用大型语言模型,并利用新的文本信息来指导视觉模型的训练,以进行少样本图像识别。然而,这些方法往往依赖于来自其他模态的信息或需要生成额外的外部提示来参与自注意计算,由于自注意层的二次复杂性,导致计算成本增加。相比之下,我们提出的自提示机制产生内在的自提示信息,这些信息传输到Transformer的深层,并且是参数高效的,只需要微调少量的参数就可以适应不同场景下的少样本图像识别任务。

方法

image.png
图2:我们提出的自提示机制通过在空间维度和通道维度上选择网络的深层特征,生成自提示信息,并将该自提示信息传递到网络的更深层,从而修改自注意的计算过程,指导网络训练。

综述

提出的自提示机制的核心是根据未见的类或域自适应地调整模型参数。我们提出的方法的完整流程如图2所示。首先,我们将支持集图像和查询集图像输入到模型中,并通过视觉变换(Vision Transformer, ViT)提取特征(Dosovitskiy et al . 2020)。同时,我们对网络深层的语义特征进行特征选择,生成自提示信息。同时,我们传播生成的自提示信息,指导网络深层自注意计算过程的训练过程。值得注意的是,在元训练中,我们训练图像编码器的参数,而在元测试中,我们利用提出的参数高效调优方法对少量参数进行微调。

自我提示机制

Self-Prompt Generation and Projection

人类可以总结从以前的任务中获得的经验和教训,使他们能够在遇到类似或相关的任务时根据过去的经验调整策略和纠正方向(LEE 2002;Yu and Dayan 2004)。提出的自提示机制通过提取和提炼网络的深层特征,并以自上而下的方式对网络进行微调,以适应不同的看不见的类别,模拟了人类的这一过程。具体来说,我们使用标准的ViT模型作为主干,并将自提示机制应用到Transformer结构的最后三层。为了保证自提示信息提取的准确性,我们在网络的空间和通道维度上进行特征选择。具体来说,我们首先将空间维度选择应用于特征 F ∈ R N × D F\in R^{N\times D} FRN×D,其中N表示标记的数量,D表示每个标记所映射到的特征的维度。随后,训练一个可学习的空间提示向量 s ∈ R D s \in R^D sRD并进行归一化,然后将其与同样归一化的深层特征 F ∈ R N × D F\in R^{N\times D} FRN×D逐元素相乘,得到向量 m m m:
m = N o r m ( F ) × N o r m ( s ) m =Norm(F) \times Norm(s) m=Norm(F)×Norm(s)
然后,通过舍入运算得到空间维度的掩模向量 m ∈ R D m \in R^D mRD,公式如下:
image.png
其中 i i i的取值范围为1 ~ n,最后利用 m ∈ R N m \in R^N mRN对深度特征 F ∈ R N × D F\in R^{N\times D} FRN×D进行掩码运算,从而实现空间维度的特征选择。具体计算过程如下:
image.png
式中⊙为广播的元素产品, F s F_s Fs为空间选择后得到的特征。同时,我们还定义了一个可学习矩阵 C ∈ R N × D C\in R^{N\times D} CRN×D,将其与经过空间掩码处理后的矩阵相乘,选择通道相关的特征,从而生成通道选择 F c F_c Fc后得到的特征。具体计算过程如下:
image.png
值得注意的是,上述的空间提示向量 s ∈ R D s \in R^D sRD和通道提示矩阵 C ∈ R N × D C\in R^{N\times D} CRN×D都是可训练的。此外,我们的网络能够自适应地调整不同类别或领域的特征,以适应单域或跨域场景下的少样本识别任务。此外,网络的不同深度表明了捕获和强调不同特征集的专业化。较浅的层主要强调图像的纹理和细节,而较深的层更多地关注语义信息。同时,对于分类任务来说,图像中包含的语义信息是至关重要的。因此,在网络的训练过程中,我们为backbone的后三层生成自提示信息

Self-Prompt Projection.

我们分别采用了三种可选的投影方法:恒等映射、线性映射和MLP映射。以MLP投影为例,自提示投影过程如下:
image.png
其中 P ∈ R N × D P\in R^{N\times D} PRN×D是我们生成的最终自提示矩阵。通过进一步投射自提示信息,指导网络训练过程的信息可以调整以适应未知的类或域。值得注意的是,不同的映射方法对应不同数量的可调参数,我们将在实验部分进一步介绍投影方法的选择。本文默认采用单位映射方法。

Self-Prompt Attention.

受人类认知过程的启发,个体可以根据不同的任务要求调整自己的策略,我们同样指导了更深层次网络层自关注计算过程中查询向量的初始化。具体来说,我们要求网络知道“查询什么”。因此,我们对生成的自提示信息 P ∈ R N × D P\in R^{N\times D} PRN×D进行重构,使其与查询向量的维度匹配,然后将其相加。这个修改的目的是引导网络的学习过程。具体而言,自我注意计算(Vaswani et al . 2017)修改如下:
image.png
其中, X ∈ R N × D X\in R^{N\times D} XRN×D为原始自关注计算过程的输入, P ∈ R N × D P\in R^{N\times D} PRN×D为上一节生成的自提示矩阵, d k \sqrt{d_k} dk 为比例因子。通过在自注意的训练过程中使用自提示信息作为指导,网络可以根据新类或新领域的不同特征需求自适应地调整其学习过程。这使得网络能够有目的地学习,并在学习过程中适应不同场景下的少量识别任务。

训练过程

Meta-training.

我们采用无监督预训练模型作为模型训练的初始权值。在元训练阶段,我们采用了情景训练策略(Snell, Swersky, and Zemel 2017),该策略在基本训练数据集上模拟了少样本场景。具体来说,对于K-way-N-shot 任务,我们随机抽样K-way-N-shot 和Q-queries。一般来说,我们定义
image.png
式中, f f f为骨干网络, N k = ∑ i : y i = k N_k=\sum_{i:y_i=k} Nk=i:yi=k为支持集中k类的大小, c k c_k ck为支持集中 k k k类的原型。然后,我们利用softmax函数来计算查询图像 x q x_q xq属于类 k k k的概率:
image.png
其中K定义为支持集中类别的个数。请注意,无论k值如何,原型都可以计算,这使得我们的模型能够在各种方式,各种shot设置下进行训练。最后,我们在计算交叉熵损失后更新网络的参数:
image.png
其中 y i y_i yi是查询集的实例 x i x_i xi对应的目标输出。

Parameter-efficient tuning

在训练集 D t r a i n D_{train} Dtrain上进行元训练后,我们的SPM模型在未见过的数据 T t e s t T_{test} Ttest上进行评估,并提供支持集 S T t e s t S_{T_{test}} STtest。在这里,我们提出了一种参数高效的调优方法,通过利用支持集 S T t e s t S_{T_{test}} STtest微调自提示参数和深层相应的偏差。为此,我们通过将支持集随机划分为子支持集 S ∗ S^* S和子查询集 Q ∗ Q^* Q来模拟情景元学习,使得 S T t e s t = S ∗ ∪ Q ∗ S_{T_{test}}=S^*\cup Q^* STtest=SQ S T t e s t S_{T_{test}} STtest中参数高效调优的过程可表示为:
image.png
式中, θ T \theta^T θT为自提示参数和深层相应的偏差,损失L的计算过程与元训练阶段描述的过程一致,如式8、9、10所示。同时,需要微调的参数部分可以忽略不计(不超过总参数的2%),使得SPM可以在小支撑集 S T t e s t S_{T_{test}} STtest上快速自适应调整。在微调之后,通过使用支持集 S T t e s t S_{T_{test}} STtest预测未见查询图像的标签来评估SPM。此外,加入额外的可学习参数作为自提示,确保通过冻结编码器权重保留先验知识,并根据未见数据学习判别特征。因此,我们的方法非常适合于在有限的标记数据约束下既需要信息保留又需要网络参数自适应调整的少样本识别任务。

实验

image.png
image.png
image.png

结论

在本文中,我们提出了一种新的方法,称为自提示机制(SPM)用于少射学习,它产生并利用固有的语义特征来引导网络对未知数据的适应。同时,我们提出了一种新的参数高效调谐方法,通过微调少量参数来增强模型提取判别特征的能力。在单域和跨域数据集上对该方法的有效性进行了评估。此外,我们希望我们提出的自我提示机制能够激励和促进有潜力的后续工作。我们将在今后的工作中进一步研究有效的自我提示方法。

参考资料

论文下载(2024 AAAI)

https://ojs.aaai.org/index.php/AAAI/article/view/28297

代码地址

https://github.com/codeshop715/SPM

参考文章

https://zhuanlan.zhihu.com/p/683024622

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

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

相关文章

【yolov8分类任务-全流程】【公开数据白内障-101:101例白内障手术的视频数据集】

文章目录 1.公开数据集1.1.白内障-101:数据集文件结构1.1.1.视频文件1.1.2.注释文件(1)videos.csv(2) phases.csv(3)annotations.csv 1.2. 数据处理1.2.1.抽帧脚本全部代码(每行都有注释)1.2.2.分类任务划分数据集脚本 2.yolov8分类任务训练2…

【教程】Jetson安装PyQt5和CUDA版OpenCV

转载请注明出处:小锋学长生活大爆炸[xfxuezhagn.cn] 如果本文帮助到了你,请不吝给个[点赞、收藏、关注]哦~ 安装PyQt5 注意目前似乎只支持Python3.6!!! sudo apt install pyqt5* -y sudo apt-get install python3-pyqt…

Java | Leetcode Java题解之第89题格雷编码

题目&#xff1a; 题解&#xff1a; class Solution {public List<Integer> grayCode(int n) {List<Integer> ret new ArrayList<Integer>();for (int i 0; i < 1 << n; i) {ret.add((i >> 1) ^ i);}return ret;} }

每日一题12:Pandas:数据重塑-融合

一、每日一题 解答&#xff1a; import pandas as pddef meltTable(report: pd.DataFrame) -> pd.DataFrame:reshaped_report report.melt(id_varsproduct, var_namequarter, value_namesales)return reshaped_report 题源&#xff1a;Leetcode 二、总结 melt()函数是Pa…

Python 机器学习 基础 之 监督学习 [线性模型] 算法 的简单说明

Python 机器学习 基础 之 监督学习 [线性模型] 算法 的简单说明 目录 Python 机器学习 基础 之 监督学习 [线性模型] 算法 的简单说明 一、简单介绍 二、监督学习 算法 说明前的 数据集 说明 三、监督学习 之 线性模型 算法 1、用于回归的线性模型 2、线性回归&#xff0…

SpringCloud------Feign,Geteway

Feign 所以我们使用一门新的技术&#xff1a;声明式的http客户端Feign 第一步&#xff1a;引入依赖 <dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-openfeign</artifactId></dependency> …

Vue 封装axios

【一】准备工作 &#xff08;1&#xff09;安装必要插件 安装Axios&#xff0c;这是必要的。默认最新版 npm install axios -S 或 cnpm install axios -S安装elementui-plus&#xff0c;用于提示信息 npm install element-plus --save # 或 cnpm install element-plus --s…

Selenium自动操作鼠标的方法及示例(鼠标左右键单击、左键双击、拖动等)

天行健&#xff0c;君子以自强不息&#xff1b;地势坤&#xff0c;君子以厚德载物。 每个人都有惰性&#xff0c;但不断学习是好好生活的根本&#xff0c;共勉&#xff01; 文章均为学习整理笔记&#xff0c;分享记录为主&#xff0c;如有错误请指正&#xff0c;共同学习进步。…

五分钟“手撕”时间复杂度与空间复杂度

目录 一、算法效率 什么是算法 如何衡量一个算法的好坏 算法效率 二、时间复杂度 时间复杂度的概念 大O的渐进表示法 推导大O阶方法 常见时间复杂度计算举例 三、空间复杂度 常见时间复杂度计算举例 一、算法效率 什么是算法 算法(Algorithm)&#xff1a;就是定…

BakedSDF: Meshing Neural SDFs for Real-Time View Synthesis 论文阅读

&#xff08;水一篇博客&#xff09; 项目主页 BakedSDF: Meshing Neural SDFs for Real-Time View Synthesis 作者介绍 是 Mildenhall 和 Barron 参与的工作&#xff08;都是谷歌的&#xff09;&#xff0c;同时一作是 Lipman 的学生&#xff0c;VolSDF 的一作。本文引用…

234.回文链表

给你一个单链表的头节点 head &#xff0c;请你判断该链表是否为 回文链表 。如果是&#xff0c;返回 true &#xff1b;否则&#xff0c;返回 false 。 示例 1&#xff1a; 输入&#xff1a;head [1,2,2,1] 输出&#xff1a;true示例 2&#xff1a; 输入&#xff1a;head …

项目管理-案例重点知识(风险管理)

项目管理 : 每天进步一点点~ 活到老&#xff0c;学到老 ヾ(◍∇◍)&#xff89;&#xff9e; 何时学习都不晚&#xff0c;加油 二、风险管理 案例重点 重点内容&#xff1a; &#xff08;1&#xff09;风险划分 &#xff08;2&#xff09;SWOT 分析&#xff0c;提示清单 …

5.10.10 用于图像识别的深度残差学习

1. 介绍 深度卷积神经网络为图像分类带来了一系列突破。深度网络自然地以端到端的多层方式集成低/中/高级特征和分类器&#xff0c;并且特征的“级别”可以通过堆叠层的数量&#xff08;深度&#xff09;来丰富。 学习更好的网络是否像堆叠更多层一样容易&#xff1f; 这个问…

RK3568平台开发系列讲解(SPI篇)SPI数据的传输

🚀返回专栏总目录 文章目录 一、数据结构1.1、spi_transfer 结构体1.2、spi_message二、数据发送程序分析沉淀、分享、成长,让自己和他人都能有所收获!😄 📢 参考资料: spi_transferspi_message一、数据结构 spi 数据传输主要使用了 spi_message 和 spi_transfer 结构…

【计网】TCP中的滑动窗口

&#x1f34e;个人博客&#xff1a;个人主页 &#x1f3c6;个人专栏&#xff1a;日常聊聊 ⛳️ 功不唐捐&#xff0c;玉汝于成 目录 正文 工作原理如下&#xff1a; 结语 我的其他博客 正文 TCP&#xff08;传输控制协议&#xff09;中的滑动窗口是一种用于流量控制和拥…

数字集成电路物理设计[陈春章]——知识总结与精炼01

第一章 集成电路物理设计方法 1.1 数字集成电路设计挑战 1.2 数字集成电路设计流程 前两节内容讲述的是数字集成电路发展与流程&#xff0c;知识体系比较宏观和简单&#xff0c;请读者自行了解即可。 1.3 数字集成电路设计收敛 实现设计收敛任务&#xff1a;①数据系统;②优…

SQL——SERVER的建表主要操作

目录 一&#xff1a;数据存储问题 1.表的相关数据 2.表&#xff0c;字段&#xff0c;记录 二&#xff1a;建表 1.创建表头 2. 数据类型 3.保存数据 4.数据冗余 5.使用命令重置表 7.设置主键 一&#xff1a;数据存储问题 1.表的相关数据 表是数据库的基本单位&…

FreeRTOS学习 -- 列表和列表项

列表和列表项是 FreeRTOS 的一个数据结构&#xff0c;FreeRTOS 大量使用到了列表和列表项。 一、什么是列表和列表项 1、列表 列表是 FreeRTOS 中的一个数据结构&#xff0c;被用来跟踪 FreeRTOS 中的任务。与列表相关的全部东西都在文件 list.c 和 list.h中。 List_t 结构体…

web入门——导航栏

本专栏内容代码来自《响应式web&#xff08;HTML5CSS3Bootstrap&#xff09;》教材。 导航栏 实现代码&#xff1a; <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content&…

【JavaEE】Spring Web MVC入门:掌握Spring的MVC框架基础

目录 Spring Web MVC什么是Spring Web MVCMVC 定义什么是Spring MVC 学习Spring MVC1. 项目准备2. 建立连接 Spring Web MVC 什么是Spring Web MVC 官⽅对于 Spring MVC 的描述是这样的&#xff1a; Spring Web MVC 是基于 Servlet API 构建的原始 Web 框架&#xff0c;从⼀…