生成学习全景:从基础理论到GANs技术实战

news2025/1/13 14:49:37

本文全面探讨了生成学习的理论与实践,包括对生成学习与判别学习的比较、详细解析GANs、VAEs及自回归模型的工作原理与结构,并通过实战案例展示了GAN模型在PyTorch中的实现。

关注TechLead,分享AI全维度知识。作者拥有10+年互联网服务架构、AI产品研发经验、团队管理经验,同济本复旦硕,复旦机器人智能实验室成员,阿里云认证的资深架构师,项目管理专业人士,上亿营收AI产品研发负责人

file

一、生成学习概述

生成学习(Generative Learning)在机器学习领域中占据了重要的位置。它通过学习数据分布的方式生成新的数据实例,这在多种应用中表现出了其独特的价值。本节将深入探讨生成学习的核心概念,明确区分生成学习与判别学习,并探索生成学习的主要应用场景。

生成学习与判别学习的区别

生成学习和判别学习是机器学习中两种主要的学习方式,它们在处理数据和学习任务时有本质的区别。

判别学习(Discriminative Learning)

  • 目标:直接学习决策边界或输出与输入之间的映射关系。
  • 应用:分类和回归任务,如逻辑回归、支持向量机(SVM)。
  • 优势:通常在特定任务上更加高效,因为它们专注于区分数据类别。

生成学习(Generative Learning)

  • 目标:学习数据的整体分布,能够生成新的数据实例。
  • 应用:数据生成、特征学习、无监督学习等,如生成对抗网络(GANs)和变分自编码器(VAEs)。
  • 优势:能够捕捉数据的内在结构和分布,适用于更广泛的任务,如数据增强、新内容的创造。

生成学习的应用场景

生成学习由于其能力在模拟和学习数据的分布方面,使其在许多场景中都非常有用。

图像和视频生成

  • 概述:生成学习模型能够产生高质量、逼真的图像和视频内容。
  • 实例:GANs在这一领域尤其突出,能够生成新的人脸图像、风景图片等。

语音和音乐合成

  • 概述:模型可以学习音频数据的分布,生成自然语言语音或音乐作品。
  • 实例:深度学习技术已被用于合成逼真的语音(如语音助手)和创造新的音乐作品。

数据增强

  • 概述:在训练数据有限的情况下,生成学习可以创建额外的训练样本。
  • 实例:在医学图像分析中,通过生成新的图像来增强数据集,提高模型的泛化能力。

异常检测

  • 概述:模型通过学习正常数据的分布来识别异常或偏离标准的数据。
  • 实例:在金融领域,用于识别欺诈交易;在制造业,用于检测产品缺陷。

文本生成

  • 概述:生成模型能够编写逼真的文本,包括新闻文章、诗歌等。
  • 实例:一些先进的模型(如GPT系列)在这一领域显示了惊人的能力。

二、生成学习模型概览

file
在机器学习的众多领域中,生成学习模型因其能够学习和模拟数据的分布而显得尤为重要。这类模型的核心思想是理解和复制输入数据的底层结构,从而能够生成新的、类似的数据实例。以下是几种主要的生成学习模型及其关键特性的综述。

生成对抗网络(GANs)

生成对抗网络(GANs)是一种由两部分组成的模型:一个生成器(Generator)和一个判别器(Discriminator)。生成器的目标是产生逼真的数据实例,而判别器的任务是区分生成的数据和真实数据。这两部分在训练过程中相互竞争,生成器努力提高生成数据的质量,而判别器则努力更准确地识别真伪。通过这种对抗过程,GANs能够生成高质量、高度逼真的数据,尤其在图像生成领域表现出色。

变分自编码器(VAEs)

变分自编码器(VAEs)是一种基于神经网络的生成模型,它通过编码器将数据映射到一个潜在空间(latent space),然后通过解码器重建数据。VAEs的关键在于它们的重建过程,这不仅仅是一个简单的复制,而是对数据分布的学习和理解。VAEs在生成图像、音乐或文本等多种类型的数据方面都有出色的表现,并且由于其结构的特点,VAEs在进行特征学习和数据降维方面也显示了巨大的潜力。

自回归模型

自回归模型在生成学习中占有一席之地,尤其是在处理序列数据(如文本或时间序列)时。这类模型基于先前的数据点来预测下一个数据点,因此它们在理解和生成序列数据方面表现出色。例如,PixelRNN通过逐像素方式生成图像,每次生成下一个像素时都考虑到之前的像素。这种方法使得自回归模型在生成图像和文本方面表现出细腻且连贯的特性。

三、生成对抗网络(GANs)模型技术全解

file
生成对抗网络(GANs)是一种引人注目的深度学习模型,以其独特的结构和生成高质量数据的能力而著称。在这篇解析中,我们将深入探讨GANs的核心概念、结构、训练方法和关键技术点。

GANs的核心概念

GANs由两个主要部分组成:生成器(Generator)和判别器(Discriminator)。生成器的目的是创建逼真的数据实例,而判别器则试图区分真实数据和生成器产生的数据。这两部分在GANs的训练过程中形成一种对抗关系,相互竞争,从而推动整个模型的性能提升。

生成器(Generator)

  • 目标:学习数据的分布,生成逼真的数据实例。
  • 方法:通常使用一个深度神经网络,通过随机噪声作为输入,输出与真实数据分布相似的数据。

判别器(Discriminator)

  • 目标:区分输入数据是来自真实数据集还是生成器。
  • 方法:同样使用深度神经网络,输出一个概率值,表示输入数据是真实数据的可能性。

GANs的结构

GANs的核心在于其生成器和判别器的博弈。生成器试图生成尽可能逼真的数据以“欺骗”判别器,而判别器则努力学习如何区分真伪。这种结构创造了一个动态的学习环境,使得生成器和判别器不断进化。

网络结构

  • 生成器:通常是一个反卷积网络(Deconvolutional Network),负责从随机噪声中生成数据。
  • 判别器:通常是一个卷积网络(Convolutional Network),用于判断输入数据的真实性。

GANs的训练方法

GANs的训练过程是一个迭代过程,其中生成器和判别器交替更新。

训练过程

  1. 判别器训练:固定生成器,更新判别器。使用真实数据和生成器生成的数据训练判别器,目标是提高区分真假数据的能力。
  2. 生成器训练:固定判别器,更新生成器。目标是生成更加逼真的数据,以使判别器更难以区分真伪。

损失函数

  • 判别器损失:通常使用交叉熵损失函数,量化判别器区分真实数据和生成数据的能力。
  • 生成器损失:同样使用交叉熵损失函数,但目标是使生成的数据被判别器误判为真实数据。

GANs的关键技术点

训练稳定性

GANs的训练过程可能会非常不稳定,需要仔细调整超参数和网络结构。常见的问题包括模式崩溃(Mode Collapse)和梯度消失。

模式崩溃

当生成器开始产生有限类型的输出,而忽略了数据分布的多样性时,就会发生模式崩溃。这通常是因为判别器过于强大,导致生成器找到了欺骗判别器的“捷径”。

梯度消失

在GANs中,梯度消失通常发生在判别器过于完美时,生成器的梯度

变得非常小,导致学习停滞。

解决方案

  • 架构调整:如使用深度卷积GAN(DCGAN)等改进的架构。
  • 正则化和惩罚:如梯度惩罚(Gradient Penalty)。
  • 条件GANs:通过提供额外的条件信息来帮助生成器和判别器的训练。

四、变分自编码器(VAEs)模型技术全解

file
变分自编码器(VAEs)是一种强大的生成模型,在机器学习和深度学习领域中得到了广泛的应用。VAEs通过学习数据的潜在表示(latent representation)来生成新的数据实例。本节将全面深入地探讨VAEs的工作原理、网络结构、训练方法及其在实际应用中的价值。

VAEs的工作原理

VAEs的核心思想是通过潜在空间(latent space)来表示数据,这个潜在空间是数据的压缩表示,捕捉了数据的关键特征。VAEs由两个主要部分组成:编码器(Encoder)和解码器(Decoder)。

编码器(Encoder)

编码器的作用是将输入数据映射到潜在空间。它输出潜在空间中的两个参数:均值(mean)和方差(variance)。这些参数定义了一个概率分布,从中可以抽取潜在表示。

解码器(Decoder)

解码器的任务是从潜在表示重构数据。它接收潜在空间中的点并生成与原始输入数据相似的数据。

VAEs的网络结构

VAEs的网络结构通常包括多层全连接层或卷积层,具体结构取决于输入数据的类型。对于图像数据,通常使用卷积层;对于文本或序列数据,则使用循环神经网络(RNN)或变换器(Transformer)。

潜在空间

潜在空间是VAEs的关键,它允许模型捕捉数据的内在结构。在这个空间中,相似的数据点被映射到靠近的位置,这使得生成新数据变得可行。

VAEs的训练方法

VAEs的训练涉及最大化输入数据的重构概率的同时,确保潜在空间的分布接近先验分布(通常是正态分布)。

重构损失

重构损失测量解码器生成的数据与原始输入数据之间的差异。这通常通过均方误差(MSE)或交叉熵损失来实现。

KL散度

KL散度用于量化编码器输出的概率分布与先验分布之间的差异。最小化KL散度有助于保证潜在空间的平滑和连续性。

VAEs的价值和应用

VAEs在多种领域都有显著的应用价值。

数据生成

由于VAEs能够捕捉数据的潜在分布,它们可以用于生成新的、逼真的数据实例,如图像、音乐等。

特征提取和降维

VAEs在潜在空间中提供了数据的紧凑表示,这对特征提取和降维非常有用,尤其是在复杂数据集中。

异常检测

VAEs可以用于异常检测,因为异常数据点通常不会被映射到潜在空间的高密度区域。

五、自回归模型技术全解

file
自回归模型在生成学习领域中占据了独特的位置,特别是在处理序列数据如文本、音乐或时间序列分析等方面。这些模型的关键特性在于利用过去的数据来预测未来的数据点。在本节中,我们将全面深入地探讨自回归模型的工作原理、结构、训练方法及其应用价值。

自回归模型的工作原理

自回归模型的核心思想是利用之前的数据点来预测下一个数据点。这种方法依赖于假设:未来的数据点与过去的数据点有一定的相关性。

序列数据的处理

对于序列数据,如文本或时间序列,自回归模型通过学习数据中的时间依赖性来生成或预测接下来的数据点。这意味着模型的输出是基于先前观察到的数据序列。

自回归模型的网络结构

自回归模型可以采用多种网络结构,具体取决于应用场景和数据类型。

循环神经网络(RNNs)

对于时间序列数据或文本,循环神经网络(RNNs)是常用的选择。RNN能够处理序列数据,并且能够记忆先前的信息,这对于捕捉时间序列中的长期依赖关系至关重要。

卷积神经网络(CNNs)

在处理像素数据时,如图像生成,卷积神经网络(CNNs)也可以用于自回归模型。例如,PixelCNN通过按顺序生成图像中的每个像素来创建完整的图像。

自回归模型的训练方法

自回归模型的训练通常涉及最大化数据序列的条件概率。

最大似然估计

自回归模型通常使用最大似然估计来训练。这意味着模型的目标是最大化给定之前观察到的数据点后,生成下一个数据点的概率。

序列建模

在训练过程中,模型学习如何根据当前序列预测下一个数据点。这种方法对于文本生成或时间序列预测尤其重要。

自回归模型的价值和应用

自回归模型在许多领域都显示出了其独特的价值。

文本生成

在自然语言处理(NLP)中,自回归模型被用于文本生成任务,如自动写作和语言翻译。

音乐生成

在音乐生成中,这些模型能够基于已有的音乐片段来创建新的旋律。

时间序列预测

在金融、气象学和其他领域,自回归模型用于预测未来的数据点,如股票价格或天气模式。

六、GAN模型案例实战

在本节中,我们将通过一个具体的案例来演示如何使用PyTorch实现一个基础的生成对抗网络(GAN)。这个案例将重点放在图像生成上,展示如何训练一个GAN模型以生成手写数字图像,类似于MNIST数据集中的图像。

场景描述

目标:训练一个GAN模型来生成看起来像真实手写数字的图像。

数据集:MNIST手写数字数据集,包含0到9的手写数字图像。

输入:生成器将接收一个随机噪声向量作为输入。

输出:生成器输出一张看起来像真实手写数字的图像。

处理过程

  1. 数据准备:加载并预处理MNIST数据集。
  2. 模型定义:定义生成器和判别器的网络结构。
  3. 训练过程:交替训练生成器和判别器。
  4. 图像生成:使用训练好的生成器生成图像。

PyTorch实现

1. 导入必要的库

import torch
import torch.nn as nn
import torch.optim as optim
from torchvision import datasets, transforms
from torch.utils.data import DataLoader
import matplotlib.pyplot as plt

2. 数据准备

transform = transforms.Compose([
    transforms.ToTensor(),
    transforms.Normalize((0.5,), (0.5,))
])

train_dataset = datasets.MNIST(root='./data', train=True, download=True, transform=transform)
train_loader = DataLoader(train_dataset, batch_size=64, shuffle=True)

3. 定义模型

生成器
class Generator(nn.Module):
    def __init__(self):
        super(Generator, self).__init__()
        self.model = nn.Sequential(
            nn.Linear(100, 256),
            nn.LeakyReLU(0.2),
            nn.Linear(256, 512),
            nn.LeakyReLU(0.2),
            nn.Linear(512, 1024),
            nn.LeakyReLU(0.2),
            nn.Linear(1024, 784),
            nn.Tanh()
        )

    def forward(self, x):
        return self.model(x).view(-1, 1, 28, 28)
判别器
class Discriminator(nn.Module):
    def __init__(self):
        super(Discriminator, self).__init__()
        self.model = nn.Sequential(
            nn.Linear(784, 1024),
            nn.LeakyReLU(0.2),
            nn.Dropout(0.3),
            nn.Linear(1024, 512),
            nn.LeakyReLU(0.2),
            nn.Dropout(0.3),
            nn.Linear(512, 256),
            nn.LeakyReLU(0.2),
            nn.Linear(256, 1),
            nn.Sigmoid()
        )

    def forward(self, x):
        x = x.view(x.size(0), -1)
        return self.model(x)

4. 初始化模型和优化器

generator = Generator()
discriminator = Discriminator()

optimizer_G = optim.Adam(generator.parameters(), lr=0.0002)
optimizer_D = optim.Adam(discriminator.parameters(), lr=0.0002)

criterion = nn.BCELoss()

5. 训练模型

epochs = 50
for epoch in range(epochs):
    for i, (images, _) in enumerate(train_loader):
        # 真实图像标签是1,生成图像标签是0
        real_labels = torch.ones(images.size(0), 1)
        fake_labels = torch.zeros(images.size(0), 1)

        # 训练判别器
        outputs = discriminator(images)
        d_loss_real = criterion(outputs, real_labels)
        real_score = outputs

        z = torch.randn(images.size(0), 100)
        fake_images = generator(z)
        outputs = discriminator(fake_images.detach())
        d_loss_fake = criterion(outputs, fake_labels)
        fake_score = outputs

        d_loss = d_loss_real + d_loss_fake
        optimizer_D.zero_grad()
        d_loss.backward()
        optimizer_D.step()

        # 训练生成器
        outputs = discriminator(fake_images)
        g_loss = criterion(outputs, real_labels)



        optimizer_G.zero_grad()
        g_loss.backward()
        optimizer_G.step()
        
    print(f'Epoch [{epoch+1}/{epochs}], d_loss: {d_loss.item():.4f}, g_loss: {g_loss.item():.4f}')

6. 生成图像

z = torch.randn(1, 100)
generated_images = generator(z)
plt.imshow(generated_images.detach().numpy().reshape(28, 28), cmap='gray')
plt.show()

七、总结

在深入探讨了生成学习的核心概念、主要模型、以及实际应用案例后,我们可以对这一领域有一个更加全面和深入的理解。生成学习不仅是机器学习的一个分支,它更是开启了数据处理和理解新视角的关键。

生成学习的多样性和灵活性

生成学习模型,如GANs、VAEs和自回归模型,展示了在不同类型的数据和应用中的多样性和灵活性。每种模型都有其独特的特点和优势,从图像和视频的生成到文本和音乐的创作,再到复杂时间序列的预测。这些模型的成功应用证明了生成学习在捕捉和模拟复杂数据分布方面的强大能力。

创新的前沿和挑战

生成学习领域正处于不断的创新和发展之中。随着技术的进步,新的模型和方法不断涌现,推动着这一领域的边界不断扩展。然而,这也带来了新的挑战,如提高模型的稳定性和生成质量、解决训练过程中的问题(如模式崩溃),以及增强模型的解释性和可控性。

跨学科的融合和应用

生成学习在多个学科之间架起了桥梁,促进了不同领域的融合和应用。从艺术创作到科学研究,从商业智能到社会科学,生成学习的应用为这些领域带来了新的视角和解决方案。这种跨学科的融合不仅推动了生成学习技术本身的进步,也为各领域的发展提供了新的动力。

未来发展的趋势

未来,我们可以预见生成学习将继续在模型的复杂性、生成质量、以及应用领域的广度和深度上取得进步。随着人工智能技术的发展,生成学习将在模仿和扩展人类创造力方面发挥越来越重要的作用,同时也可能带来关于伦理和使用的新讨论。

关注TechLead,分享AI全维度知识。作者拥有10+年互联网服务架构、AI产品研发经验、团队管理经验,同济本复旦硕,复旦机器人智能实验室成员,阿里云认证的资深架构师,项目管理专业人士,上亿营收AI产品研发负责人

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

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

相关文章

Visual Studio Code 连接远程服务器方法

1、输入用户名和服务器ip连接远程服务器 2、选择配置文件 配置文件路径:C:\Users\Administrator\.ssh\config config的内容大致如下: Host 192.168.134.3HostName 192.168.134.3User zhangshanHost 192.168.134.3HostName 192.168.134.3User lisiHost…

Open CASCADE学习|一种快速定位缺失的链接库的方法

OCCT代码中,缺少链接库一般报错LNK2019、LNK1120等,如下表所示。该错误说明中提供了类名及成员函数,这是找到缺少的链接库的线索。 严重性 代码 说明 项目 文件 行 禁止显示状态 详细信息 错误 LNK2019 无法解析的外部符号 "p…

C/C++动态内存管理

文章目录 前言1.C/C内存分布2.C语言中动态内存管理方式:malloc/calloc/realloc/free3.C内存管理方式3.1 new/delete操作内置类型3.2 new和delete操作自定义类型 4. operator new与operator delete函数4.1 operator new与operator delete函数 5. new和delete的实现原…

Python实用小工具(4)——邮件轰炸机,给朋友搞点乐子(附源码+exe文件)

欢迎来到MatpyMaster!今天我们将使用Python来批量发送邮件,让你的邮件推送变得更加高效。废话不多说,直接开搞!使用声明: 请确保你的邮箱开启了SMTP服务,并获取了授权码。 选择合适的发送间隔,…

创建mysql普通用户

一、创建mysql普通用户的原因: 权限控制:MySQL的权限系统允许您为每个用户分配特定的权限。通过创建普通用户,您可以根据需要为每个用户分配特定的数据库和表权限,而不是将所有权限授予一个全局管理员用户。这有助于提高数据库的…

2024年华夏银行总行社会招聘公告

信息科技部自动化测试与开发类岗  工作地点:北京市 学历要求:本科及以上 工作职责 1、持续推进自动化测试的开展,提升自动化测试覆盖率,包括方案设计、测试分析、测试执行和总结等。 2、负责自动化测试工具和框架搭建,根据…

关于报错 curl: (56) Recv failure: Connection reset by peer

curl ip没问题 curl localhost 则报错 curl: (56) Recv failure: Connection reset by peer 出现这个报错有很多原因, 其中之一就是terminal代理 而关闭代理应用之后, 其实由于配置的终端都是 export指定的代理 所以导致还是一直报错. 通过 curl -v 可以发现 指向了代理ip和…

关于网络安全,你了解多少?

随着互联网技术的飞速发展,网络安全问题日益凸显。国际标准化组织(ISO)对计算机网络安全做出了明确定义:为保护数据处理系统而采取的技术和管理的安全措施,旨在保护计算机硬件、软件和数据免受偶然和故意原因造成的破坏…

Apipost IDEA插件,真的超好用

IDEA是一款功能强大的集成开发环境(IDE),它可以帮助开发人员更加高效地编写、调试和部署软件应用程序。我们在编写完接口代码后需要进行接口调试等操作,一般需要打开额外的调试工具。 今天给大家介绍一款IDEA插件:Api…

明年评职称,现在就要准备论文了吗?

明年评职称不仅需要提前补好继续教育课时,同样的还需要准备好论文和业绩材料,初级职称的相对来说对论文和业绩要求不高,但是中高级职称业绩和论文的质量代表着你的评审通过率,那为什么需要提前准备好呢?甘建二再给大家…

相机成像之图像传感器与ISP【四】

文章目录 1、图像传感器基础1.1 基础原理——光电效应1.2 基础的图像传感器设计1.3 衡量传感器效率的一个关键指标:光量子效率(QE)1.4 感光单元的响应1.5 像素的满阱容量1.6 像素尺寸和填充比例1.7 微透镜的作用1.8 光学低通滤波器简介1.9 传…

web开发学习笔记(1.html css)

css负责布局 js负责动作 2.磁盘路径 3.水平线标签 4.引入css 5.无语义标签 6.选择器 7.播放视频和音频 8.换行 <br> 9.段落标签 <p></p> 10.首行缩进 11.边距 12.盒子模型&#xff0c;居中显示&#xff0c; margin后面的四个值顺序为上右下左&#…

原生微信小程序-两次设置支付密码校验,密码设置二次确认

效果 具体代码 1、wxml <view style"{{themeColor}}"><view classcontainer><view class"password_content"><view wx:if{{type 1}}><view class"title"><view class"main_title">设置支付密码…

[Vulnhub靶机] DriftingBlues: 6

[Vulnhub靶机] DriftingBlues: 6靶机渗透思路及方法&#xff08;个人分享&#xff09; 靶机下载地址&#xff1a; https://download.vulnhub.com/driftingblues/driftingblues6_vh.ova 靶机地址&#xff1a;192.168.67.25 攻击机地址&#xff1a;192.168.67.3 一、信息收集 …

使用脚本把springboot程序部署到k8s上

一般我们部署写4个文件就行了 首先分别写 Dockerfile1package.sh2build.shdocker_push.sh Dockerfile # 基于jdk1.8 FROM openjdk:8-jdk-alpine RUN echo "Asia/Shanghai" > /etc/timezone RUN mkdir /app WORKDIR /appCOPY ./monitor-flink-1.0.jar /appEXPO…

Java 数据结构篇-实现 AVL 树的核心方法

&#x1f525;博客主页&#xff1a; 【小扳_-CSDN博客】 ❤感谢大家点赞&#x1f44d;收藏⭐评论✍ 文章目录 1.0 AVL 树的说明 2.0 AVL 树的成员变量及其构造方法 3.0 实现 AVL 树的核心方法 3.1 获取当前节点的高度 height(AVLNode node) 3.2 更新当前节点的高度 updateHeig…

[力扣 Hot100]Day2 字母异位词分组

题目描述 给你一个字符串数组&#xff0c;请你将 字母异位词 组合在一起。可以按任意顺序返回结果列表。 字母异位词 是由重新排列源单词的所有字母得到的一个新单词。 出处 思路 这题有点考阅读理解&#xff0c;意思就是把输入数组中的所含字母相同但顺序不同的单词放到同…

YOLOv8-Seg改进:轻量化改进 | 超越RepVGG!浙大阿里提出OREPA:在线卷积重参数化

🚀🚀🚀本文改进:OREPA在线卷积重参数化巧妙的和YOLOV8结合,并实现轻量化 🚀🚀🚀YOLOv8-seg创新专栏:http://t.csdnimg.cn/KLSdv 学姐带你学习YOLOv8,从入门到创新,轻轻松松搞定科研; 1)手把手教你如何训练YOLOv8-seg; 2)模型创新,提升分割性能; 3)独家…

创建型模式 | 建造者模式

一、建造者模式 1、原理 建造者模式又叫生成器模式&#xff0c;是一种对象的构建模式。它可以将复杂对象的建造过程抽象出来&#xff0c;使这个抽象过程的不同实现方法可以构造出不同表现&#xff08;属性&#xff09;的对象。创建者模式是一步一步创建一个复杂的对象&#xf…

使用SpringCache操作Redis缓存数据

SpringCache概念 SpringCache是一个框架&#xff0c;实现了基于注解的缓存功能&#xff0c;只需要简单的加一个注解&#xff0c;就能实现缓存功能。 SpringCache提供了一层抽象&#xff0c;底层可以切换不同的缓存实现&#xff0c;例如&#xff1a; EHCacheCaffeineRedis 使…