imgaug库指南(26):从入门到精通的【图像增强】之旅(万字长文!)

news2025/1/11 6:55:08

引言

在深度学习和计算机视觉的世界里,数据是模型训练的基石,其质量与数量直接影响着模型的性能。然而,获取大量高质量的标注数据往往需要耗费大量的时间和资源。正因如此,数据增强技术应运而生,成为了解决这一问题的关键所在。而imgaug,作为一个功能强大的图像增强库,为我们提供了简便且高效的方法来扩充数据集。本系列博客将带您深入了解如何运用imgaug进行图像增强,助您在深度学习的道路上更进一步。我们将从基础概念讲起,逐步引导您掌握各种变换方法,以及如何根据实际需求定制变换序列。让我们一起深入了解这个强大的工具,探索更多可能性,共同推动深度学习的发展。


前期回顾

链接主要内容
imgaug库指南(11):从入门到精通的【图像增强】之旅详细介绍了imgaug库的数据增强方法 —— 加性高斯噪声(AdditiveGaussianNoise方法)
imgaug库指南(12):从入门到精通的【图像增强】之旅详细介绍了imgaug库的数据增强方法 —— 加性拉普拉斯噪声(AdditiveLaplaceNoise方法)
imgaug库指南(13):从入门到精通的【图像增强】之旅详细介绍了imgaug库的数据增强方法 —— 加性泊松噪声(AdditivePoissonNoise方法)
imgaug库指南(14):从入门到精通的【图像增强】之旅详细介绍了imgaug库的数据增强方法 —— 乘法运算(Multiply方法)
imgaug库指南(15):从入门到精通的【图像增强】之旅详细介绍了imgaug库的数据增强方法 —— 乘法运算(MultiplyElementwise方法)
imgaug库指南(16):从入门到精通的【图像增强】之旅详细介绍了imgaug库的数据增强方法 —— Cutout方法
imgaug库指南(17):从入门到精通的【图像增强】之旅详细介绍了imgaug库的数据增强方法 —— Dropout方法
imgaug库指南(18):从入门到精通的【图像增强】之旅详细介绍了imgaug库的数据增强方法 —— CoarseDropout方法
imgaug库指南(19):从入门到精通的【图像增强】之旅详细介绍了imgaug库的数据增强方法 —— Dropout2D方法
imgaug库指南(20):从入门到精通的【图像增强】之旅详细介绍了imgaug库的数据增强方法 —— TotalDropout方法
imgaug库指南(21):从入门到精通的【图像增强】之旅详细介绍了imgaug库的数据增强方法 —— ReplaceElementwise方法
imgaug库指南(22):从入门到精通的【图像增强】之旅详细介绍了imgaug库的数据增强方法 —— ImpulseNoise方法
imgaug库指南(23):从入门到精通的【图像增强】之旅详细介绍了imgaug库的数据增强方法 —— SaltAndPepper方法
imgaug库指南(24):从入门到精通的【图像增强】之旅(干货!万字长文!)详细介绍了imgaug库的数据增强方法 —— CoarseSaltAndPepper方法

在本博客中,我们将向您详细介绍imgaug库的数据增强方法 —— CoarseSalt方法


CoarseSalt方法

功能介绍

iaa.CoarseSaltimgaug库中的一个方法,用于在图像中添加粗粒度的盐噪声。以下是三个使用场景举例:

  1. 模拟真实世界的图像:在图像处理和计算机视觉应用中,经常需要使用真实世界的图像作为数据集。然而,收集这些图像可能是一项挑战,尤其是当涉及到特定的场景或条件时。使用iaa.CoarseSalt可以在图像中添加粗粒度的盐噪声,模拟现实世界中由于各种因素(如传感器噪声、环境条件等)导致的图像质量下降。通过这种方式,可以生成更多样化的训练数据集,提高模型的泛化能力。
  2. 数据增强:在机器学习和深度学习中,数据增强是一种常用的技术,用于通过变换原始图像来创建新的训练样本。iaa.CoarseSalt可以与其它数据增强方法结合使用,为训练数据集添加噪声,以增加模型的鲁棒性。通过在训练过程中暴露模型于带有噪声的图像,可以提高模型在实际应用中对噪声的适应性,从而减少噪声对模型性能的影响。
  3. 测试算法的鲁棒性:在评估机器学习算法的性能时,一个重要的考虑因素是算法的鲁棒性。鲁棒性是指算法在面对噪声、异常值和其他干扰时的健壮性。使用iaa.CoarseSalt可以模拟图像中的噪声,并观察算法在这些噪声下的表现。通过这种方式,可以对算法的鲁棒性进行评估和比较,并针对改进算法的鲁棒性进行优化。

语法

import imgaug.augmenters as iaa
aug = iaa.CoarseSalt(p=(0.02, 0.1), size_px=None, size_percent=None, per_channel=False, min_size=3, seed=None, name=None, random_state='deprecated', deterministic='deprecated')

以下是对iaa.CoarseSalt方法中各个参数的详细介绍:

  1. p

    • 类型:可以是浮点数|浮点数元组|浮点数列表。
    • 描述:将像素替换为盐噪声的概率。
      • p为浮点数,则表示将像素替换为盐噪声的概率;
      • p为元组(a, b),则将像素替换为盐噪声的概率为从区间[a, b]中采样的随机数;
      • p为列表,则将像素替换为盐噪声的概率为从列表中随机采样的浮点数;
  2. size_px:

    • 类型:可以是整数|整数元组|整数列表。
    • 描述:定义每个噪声方块的大小。
      • size_px为整数,例如size_px为3,且RGB图像的宽和高都为300。则每个噪声方块大小为(H/size_px, W/size_px), 即(100, 100) ==> 将RGB图像分成9宫格, 每个宫格形状(100, 100), 根据参数p的大小确定有多少个宫格会被替换为盐噪声方块;
      • size_px为元组(a, b),则每个噪声方块大小为(H/size, W/size), size为从区间[a, b]中采样的随机数;
      • size_px为列表,则每个噪声方块大小为(H/size, W/size), size为从列表中随机采样的数;
    • 注意:若size_pxNone,则size_percent参数必须设置。
  3. size_percent:

    • 类型:可以是浮点数|浮点数元组|浮点数列表。
    • 描述:定义每个噪声方块的大小。
      • size_percent为浮点数0.02,则每个噪声方块大小为(1/size_percent, 1/size_percent), 即(50, 50);
      • size_percent为元组(a, b),则每个噪声方块大小为(1/size, 1/size), size为从区间[a, b]中采样的随机数;
      • size_percent为列表,则每个噪声方块大小为(1/size, 1/size), size为从列表中随机采样的数;
    • 注意:若size_percentNone,则size_px参数必须设置。
  4. per_channel

    • 类型:布尔值(TrueFalse)|浮点数。
    • 描述
      • per_channelTrue,则RGB图像的每个像素位置所对应的三个通道像素值可能不会同时替换为盐噪声方块 ==> RGB图像会出现彩色失真;
      • per_channelFalse,则RGB图像的每个像素位置所对应的三个通道像素值会同时替换为盐噪声方块;
      • per_channel为区间[0,1]的浮点数,假设per_channel=0.6,那么对于60%的图像,per_channelTrue;对于剩余的40%的图像,per_channelFalse
  5. min_size

    • 类型:整数
    • 描述:考虑到错误地设置size_percentsize_px参数会导致整个图像都被替换成盐噪声,因此通过设置min_size来确保最大的噪声方块不至于太大。
  6. seed

    • 类型:整数|None
    • 描述:用于设置随机数生成器的种子。如果提供了种子,则结果将是可重复的。默认值为None,表示随机数生成器将使用随机种子。
  7. name

    • 类型:字符串或None
    • 描述:用于标识增强器的名称。如果提供了名称,则可以在日志和可视化中识别该增强器。默认值为None,表示增强器将没有名称。

示例代码

  1. 使用不同的p
import cv2
import imgaug.augmenters as iaa
import matplotlib.pyplot as plt

# 读取图像
img_path = r"D:\python_project\lena.png"
img = cv2.imread(img_path)
image = cv2.cvtColor(img, cv2.COLOR_BGR2RGB)

# 创建数据增强器
aug1 = iaa.CoarseSalt(p=0.2, size_px=3, size_percent=None, per_channel=False, min_size=3, seed=0)
aug2 = iaa.CoarseSalt(p=0.5, size_px=3, size_percent=None, per_channel=False, min_size=3, seed=0)
aug3 = iaa.CoarseSalt(p=0.8, size_px=3, size_percent=None, per_channel=False, min_size=3, seed=0)

# 对图像进行数据增强
Augmented_image1 = aug1(image=image)
Augmented_image2 = aug2(image=image)
Augmented_image3 = aug3(image=image)

# 展示原始图像和数据增强后的图像
fig, axes = plt.subplots(2, 2, figsize=(10, 10))
axes[0][0].imshow(image)
axes[0][0].set_title("Original Image")
axes[0][1].imshow(Augmented_image1)
axes[0][1].set_title("Augmented Image1")
axes[1][0].imshow(Augmented_image2)
axes[1][0].set_title("Augmented Image2")
axes[1][1].imshow(Augmented_image3)
axes[1][1].set_title("Augmented Image3")
plt.show()

运行结果如下:

图1 原图及数据增强结果可视化(使用不同的p参数)

可以从图1看到:

  • p参数设置的越接近1.0时,图像增强后的新图像将会出现更多的盐噪声方块。
  • 由于size_px为3,且RGB图像的宽和高都接近300,因此每个盐噪声方块的尺寸都接近(100, 100) ==> 先把RGB图像分为9宫格,即9个相同大小的区域,再根据p确定将多少个区域替换为盐噪声方块。
  1. 使用不同的size_px
import cv2
import imgaug.augmenters as iaa
import matplotlib.pyplot as plt

# 读取图像
img_path = r"D:\python_project\lena.png"
img = cv2.imread(img_path)
image = cv2.cvtColor(img, cv2.COLOR_BGR2RGB)

# 创建数据增强器
aug1 = iaa.CoarseSalt(p=0.5, size_px=3, size_percent=None, per_channel=False, min_size=3, seed=0)
aug2 = iaa.CoarseSalt(p=0.5, size_px=6, size_percent=None, per_channel=False, min_size=3, seed=0)
aug3 = iaa.CoarseSalt(p=0.5, size_px=10, size_percent=None, per_channel=False, min_size=3, seed=0)

# 对图像进行数据增强
Augmented_image1 = aug1(image=image)
Augmented_image2 = aug2(image=image)
Augmented_image3 = aug3(image=image)

# 展示原始图像和数据增强后的图像
fig, axes = plt.subplots(2, 2, figsize=(10, 10))
axes[0][0].imshow(image)
axes[0][0].set_title("Original Image")
axes[0][1].imshow(Augmented_image1)
axes[0][1].set_title("Augmented Image1")
axes[1][0].imshow(Augmented_image2)
axes[1][0].set_title("Augmented Image2")
axes[1][1].imshow(Augmented_image3)
axes[1][1].set_title("Augmented Image3")
plt.show()

运行结果如下:

图2 原图及数据增强结果可视化(使用不同的size_px参数)

可以从图2看到:

  • size_px参数设置的越大时,增强后的新图像的每个盐噪声方块的尺寸会越小。
    • size_px=3时,由于RGB图像的宽和高都接近300,因此每个盐噪声方块的尺寸都接近(100, 100) ==> 先把RGB图像分为9宫格,即9个相同大小的区域,再根据p确定将多少个区域替换为盐噪声方块。
    • size_px=6时,由于RGB图像的宽和高都接近300,因此每个盐噪声方块的尺寸都接近(50, 50) ==> 先把RGB图像分为36宫格,即36个相同大小的区域,再根据p确定将多少个区域替换为盐噪声方块。
    • size_px=10时,由于RGB图像的宽和高都接近300,因此每个盐噪声方块的尺寸都接近(30, 30) ==> 先把RGB图像分为100宫格,即100个相同大小的区域,再根据p确定将多少个区域替换为盐噪声方块。
  1. 使用不同的size_percent
import cv2
import imgaug.augmenters as iaa
import matplotlib.pyplot as plt

# 读取图像
img_path = r"D:\python_project\lena.png"
img = cv2.imread(img_path)
image = cv2.cvtColor(img, cv2.COLOR_BGR2RGB)

# 创建数据增强器
aug1 = iaa.CoarseSalt(p=0.5, size_px=None, size_percent=0.02, per_channel=False, min_size=3, seed=0)
aug2 = iaa.CoarseSalt(p=0.5, size_px=None, size_percent=0.05, per_channel=False, min_size=3, seed=0)
aug3 = iaa.CoarseSalt(p=0.5, size_px=None, size_percent=0.1, per_channel=False, min_size=3, seed=0)

# 对图像进行数据增强
Augmented_image1 = aug1(image=image)
Augmented_image2 = aug2(image=image)
Augmented_image3 = aug3(image=image)

# 展示原始图像和数据增强后的图像
fig, axes = plt.subplots(2, 2, figsize=(10, 10))
axes[0][0].imshow(image)
axes[0][0].set_title("Original Image")
axes[0][1].imshow(Augmented_image1)
axes[0][1].set_title("Augmented Image1")
axes[1][0].imshow(Augmented_image2)
axes[1][0].set_title("Augmented Image2")
axes[1][1].imshow(Augmented_image3)
axes[1][1].set_title("Augmented Image3")
plt.show()

运行结果如下:

图3 原图及数据增强结果可视化(使用不同的size_percent参数)

可以从图3看到:

  • size_percent参数设置的越大时,增强后的新图像的每个盐噪声方块的尺寸会越小(size_percent和噪声方块尺寸的关系见size_percent的参数描述)。
    • size_percent=0.02时,每个盐噪声方块的尺寸都接近(50, 50),根据p确定将多少个区域替换为盐噪声方块。
    • size_percent=0.05时,每个盐噪声方块的尺寸都接近(20, 20),根据p确定将多少个区域替换为盐噪声方块。
    • size_percent=0.1时,每个盐噪声方块的尺寸都接近(10, 10),根据p确定将多少个区域替换为盐噪声方块。
  1. per_channel设置为True
import cv2
import imgaug.augmenters as iaa
import matplotlib.pyplot as plt

# 读取图像
img_path = r"D:\python_project\lena.png"
img = cv2.imread(img_path)
image = cv2.cvtColor(img, cv2.COLOR_BGR2RGB)

# 创建数据增强器
aug1 = iaa.CoarseSalt(p=0.5, size_px=None, size_percent=0.02, per_channel=True, min_size=3, seed=0)
aug2 = iaa.CoarseSalt(p=0.5, size_px=None, size_percent=0.05, per_channel=True, min_size=3, seed=0)
aug3 = iaa.CoarseSalt(p=0.5, size_px=None, size_percent=0.1, per_channel=True, min_size=3, seed=0)

# 对图像进行数据增强
Augmented_image1 = aug1(image=image)
Augmented_image2 = aug2(image=image)
Augmented_image3 = aug3(image=image)

# 展示原始图像和数据增强后的图像
fig, axes = plt.subplots(2, 2, figsize=(10, 10))
axes[0][0].imshow(image)
axes[0][0].set_title("Original Image")
axes[0][1].imshow(Augmented_image1)
axes[0][1].set_title("Augmented Image1")
axes[1][0].imshow(Augmented_image2)
axes[1][0].set_title("Augmented Image2")
axes[1][1].imshow(Augmented_image3)
axes[1][1].set_title("Augmented Image3")
plt.show()

运行结果如下:

图4 原图及数据增强结果可视化(per_channel设置为True)

可以从图4看到:图像增强后的新图像将会出现彩色失真(不再是盐噪声)。
原因:当per_channel设置为True时,RGB的三个通道会独立进行处理,不一定能够同时替换为盐噪声块。

注意事项

  1. p的选择p参数决定了一副图像盐噪声的强度。较大的p值可能会导致新图像出现严重失真。需要根据具体场景选择合适的p
  2. size_px的选择size_px参数决定了盐噪声块的大小。错误地设置size_px值可能会导致原图完全被替换成盐噪声图像。需要根据具体场景选择合适的size_px
  3. size_percent的选择size_percent参数决定了盐噪声块的大小。错误地设置size_percent值也可能会导致原图完全被替换成盐噪声图像。需要根据具体场景选择合适的size_percent
  4. size_px和size_percent:若size_percentNone,则size_px参数必须设置;若size_pxNone,则size_percen参数必须设置;
  5. **随机性和可复现性(seed)**:如果需要可复现的结果,应该设置seed参数为一个固定的整数值。这将初始化随机数生成器,使得每次运行增强操作时都能得到相同的结果;
  6. 与其他增强操作的组合iaa.CoarseSalt可以与其他imgaug增强操作组合使用,以创建更复杂的增强管道。在组合多个增强操作时,应注意它们的顺序,因为不同的顺序可能会导致不同的最终效果。
  7. min_size的设置:合理地设置min_size可以预防因为错误地设置size_px参数或者size_percent参数导致原图被完全替换为盐噪声的问题。
  8. 谨慎设置per_channel参数:当per_channel设置为True时,RGB的三个通道会独立进行处理,导致出现彩色噪声块,并非常规的盐噪声块。

总结

iaa.CoarseSaltimgaug库中的一个图像增强方法,用于向图像中添加粗糙的盐噪声。相比于iaa.Salt,它的噪声颗粒更大,能够模拟更为粗糙的噪声模式。以下是该方法的总结:

  1. 作用:通过添加大范围的噪声块,模拟图像在恶劣条件下的噪声模式,或者用于创造特殊的艺术效果。

  2. 参数

    • p:定义了像素被替换为盐噪声(白色)的概率。
    • size_px:可用于定义噪声块的大小。
    • size_percent:可用于定义噪声块的大小。
    • per_channel:决定是否对每个通道独立地应用噪声。
    • min_size:定义噪声块的最小大小。
    • seed:用于设置随机数生成器的种子,以确保结果的可重复性。
    • name:增强器的名称。
  3. 用途

    • 增强大图像的视觉效果:在处理大图像时,通过添加大范围的噪声块来增强图像的细节和纹理。
    • 模拟恶劣天气条件下的图像:模拟由于恶劣天气(如雾、沙尘暴等)导致的较大范围的噪声干扰。
    • 创造艺术效果:通过控制噪声的大小和密度,在图像中创造特殊的艺术效果。

小结

imgaug是一个顶级的图像增强库,具备非常多的数据增强方法。它为你提供创造丰富多样的训练数据的机会,从而显著提升深度学习模型的性能。通过精心定制变换序列和参数,你能灵活应对各类应用场景,使我们在处理计算机视觉的数据增强问题时游刃有余。随着深度学习的持续发展,imgaug将在未来持续展现其不可或缺的价值。因此,明智之举是将imgaug纳入你的数据增强工具箱,为你的项目带来更多可能性。

参考链接


结尾

亲爱的读者,首先感谢抽出宝贵的时间来阅读我们的博客。我们真诚地欢迎您留下评论和意见,因为这对我们来说意义非凡。
俗话说,当局者迷,旁观者清。的客观视角对于我们发现博文的不足、提升内容质量起着不可替代的作用。
如果您觉得我们的博文给您带来了启发,那么,希望能为我们点个免费的赞/关注您的支持和鼓励是我们持续创作的动力
请放心,我们会持续努力创作,并不断优化博文质量,只为给带来更佳的阅读体验。
再次感谢的阅读,愿我们共同成长,共享智慧的果实!

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

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

相关文章

在uni-app中使用sku插件,实现商品详情页规格展示和交互。

商品详情 - SKU 模块 学会使用插件市场,下载并使用 SKU 组件,实现商品详情页规格展示和交互。 存货单位(SKU) SKU 概念 存货单位(Stock Keeping Unit),库存管理的最小可用单元,通…

电子签章服务器,如何解决无纸化最后一公里?

钉钉、飞书、企微、OA、ERP等主流企业办公系统,无法实现电子签章,往往审批后还要将合同文件打印出来再进行签章。实现无纸化办公的这最后一公里就成了难题。电子签章服务器的出现,提供了完美的解决方案。本文将从专业角度,探讨电子…

大模型压缩与优化的技术原理与创新方法

目录 前言1 模型压缩简介2 知识蒸馏3 模型剪枝3.1 结构化剪枝3.2 非结构化剪枝 4 模型量化4.1 浮点表示 vs 定点表示4.2 位数选择与性能影响4.3 量化技术 5 其他模型压缩方法5.1 Weight Sharing: 参数共享5.2 Low-rank Approximation: 低秩分解5.3 Architecture Search: 神经网…

C++ 设计模式之观察者模式

【声明】本题目来源于卡码网(题目页面 (kamacoder.com)) 【提示:如果不想看文字介绍,可以直接跳转到C编码部分】 【设计模式大纲】 前面的文章介绍了创建型模式和结构型模式,今天开始介绍行为型模式。 【简介】什么是…

Oracle AWR报告的生成和解读

Oracle AWR报告的生成和解读 一、AWR报告概念及原理 Oracle10g以后,Oracle提供了一个性能检测的工具:AWR(Automatic Workload Repository 自动工作负载库)这个工具可以自动采集Oracle运行中的负载信息,并生成与性能相…

评估文字识别准确性的方法与流程

随着信息技术的发展,文字识别技术在各个领域得到了广泛的应用。然而,在实际应用中,如何评估文字识别的准确性,一直是相关领域的一个难题。本文将介绍几种常用的文字识别准确性评估方法,以期为相关领域的研究提供参考。…

Excel 添加复选框或选项按钮(表单控件)

Excel 添加复选框或选项按钮(表单控件) 要添加复选框或选项按钮,需要使用功能区上的“开发工具”选项卡。 注意: 若要启用“开发工具”选项卡,请按照以下说明进行操作: 在 Excel 2010 和后续版本中,选择“…

主流视频压缩格式

主流的视频压缩格式有很多,它们各自适用于不同的应用场景,如在线流媒体、广播、存档等。 以下是一些广泛使用的视频压缩格式: H.264/AVC (Advanced Video Coding): 目前最为广泛使用的视频压缩标准之一,兼容性极佳,广泛…

【蓝桥杯日记】第二篇——递归问题的处理

目录 前言 递归 递归解决的问题 递归的三要素 递归的练习(由浅入深) 1.循环改为递归 2.斐波那契 3.汉诺塔问题 总结 前言 大家好呀!我是大雄!一个菜鸡!接下来的几个月和大家分享一下自己在备战蓝桥中遇到的…

微信小程序(四)页面跳转

注释很详细&#xff0c;直接上代码 新增内容 1.相对路径页面跳转 2. 绝对路径页面跳转 index.wxml <!-- navigator是块级元素&#xff0c;占一整行 --> <!-- 页面跳转url&#xff0c;相对路径 --> <navigator url"../logs/logs"><button type&…

【现代密码学】笔记6--伪随机对象的理论构造《introduction to modern cryphtography》

【现代密码学】笔记6--伪随机对象的理论构造《introduction to modern cryphtography》 写在最前面6 伪随机对象的理论构造 写在最前面 主要在 哈工大密码学课程 张宇老师课件 的基础上学习记录笔记。 内容补充&#xff1a;骆婷老师的PPT 《introduction to modern cryphtogr…

Vue中的全局组件与局部组件

聚沙成塔每天进步一点点 本文内容 ⭐ 专栏简介1. 全局组件的原理2. 局部组件的原理3. 组件注册的影响与考虑因素全局组件的使用场景&#xff1a;局部组件的使用场景&#xff1a; 4. 组合使用全局组件与局部组件 ⭐ 写在最后 ⭐ 专栏简介 Vue学习之旅的奇妙世界 欢迎大家来到 Vu…

Android 捕获native异常

11.使用google官方提供的breakpad 地址&#xff1a;Android 捕获native异常 https://github.com/google/breakpad 2.编译breakpad的so文件 2.1设置需要编译的架构 3.编译完&#xff0c;在build\intermediates\cmake\debug\obj目录下获取对应架构的so包 4.编译一个错误的so包…

MIT 6s081 lab3:page tables

Lab3: page tables 作业地址&#xff1a;Lab: page tables (mit.edu) 本实验的目标&#xff1a;修改页表、简化从用户态拷贝数据到内核态的方法 其实页表就几个操作&#xff1a;创建页表、添加PTE项&#xff0c;查找PTE项&#xff0c;清空PTE项&#xff0c;释放PTE对应的物理…

聚观早报 |一加Ace 3鸣沙金开售;地平线征程6将发布

聚观早报每日整理最值得关注的行业重点事件&#xff0c;帮助大家及时了解最新行业动态&#xff0c;每日读报&#xff0c;就读聚观365资讯简报。 整理丨Cutie 1月16日消息 一加Ace 3鸣沙金开售 地平线征程6将发布 互动短剧《谍影成双》首曝PV 台积电发布四季度财报 保时捷…

JVM实战(21)——jstat实战(2)

作者简介&#xff1a;大家好&#xff0c;我是smart哥&#xff0c;前中兴通讯、美团架构师&#xff0c;现某互联网公司CTO 联系qq&#xff1a;184480602&#xff0c;加我进群&#xff0c;大家一起学习&#xff0c;一起进步&#xff0c;一起对抗互联网寒冬 学习必须往深处挖&…

Proxy的使用方法和13种拦截操作

前言 proxy是ES6新推出的方法,功能很强大。属于元编程,也就是修改js本身的一些东西。可以对数组,对象,函数等引用类型的对象进行一些复杂的操作。 其中,大部分人应该最熟悉的莫过于vue3中使用proxy替换了defineProperty,而且还实现了本身defineProperty不能实现的一些东西。 …

Vue-API

$parent 和 $children $parent 父传子--在子组件中使用&#xff0c;放在计算属性、生命周期中&#xff1a; $children 子传父--方法中使用&#xff1a; $nextTick: $ref: 操作dom $set、$delete:

UML-实现图(组件图和部署图)

实现图是从系统的层次来描述的&#xff0c;描述硬件的组成和布局&#xff0c;描述软件系统划分和功能实现。 UML-实现图&#xff08;组件图和部署图&#xff09; 一、组件图1.组件图的元素&#xff08;1&#xff09;组件&#xff08;2&#xff09;接口&#xff08;3&#xff09…

linux系统nginx工具的一些应用和基于nginx做虚拟主机

nginx高级应用 虚拟目录监控模块配置文件创建用户名密码客户端访问 限制传输速度&#xff08;服务层&#xff09; nginx虚拟主机基于ip基于域名基于端口 nginx配置文件中的每个语句要以 ; 结尾 虚拟目录 配置文件中的server块中编辑&#xff1a;location /test {alias /usr/…