当前位置: 首页 > news >正文

30min 的OpenCV learning Note

1.安装python和pycharm与环境搭配

打开Windows终端:(win+R)(一般使用清华镜像网站安装库比较快)

pip install opencv-contrib-python -i https://pypi.mirrors.ustc.edu.cn/simple

或者

python -m pip install opencv-python -i https://pypi.tuna.tsinghua.edu.cn/simple

2.基础操作学习

库函数:import cv2;import numpy

代码解释:

ONE(打开,图像大小与窗口):

1. print(cv2.getVersionString())

  • 作用:打印当前安装的OpenCV库的版本号。这对于调试和确保你的代码与特定版本的OpenCV兼容非常有用。

  • 函数格式cv2.getVersionString() 是一个无参数的函数,它返回一个字符串,表示安装的OpenCV库的版本号。

2. image = cv2.imread("opencv_logo.jpg")

  • 作用:从指定路径加载图像文件。如果文件成功读取,图像数据将被存储在变量image中;如果文件不存在或无法读取,image将被设置为None

  • 函数格式cv2.imread(filepath, flags=cv2.IMREAD_COLOR)

    • filepath:图像文件的路径。

    • flags(可选):指定如何读取图像。常用的值有:

      • cv2.IMREAD_COLOR:加载彩色图像。任何图像的透明度都会被忽略(这是默认值)。

      • cv2.IMREAD_GRAYSCALE:以灰度模式加载图像。

      • cv2.IMREAD_UNCHANGED:包括alpha通道的加载图像。

3. print(image.shape)

  • 作用:打印图像的形状。对于彩色图像,这将是一个包含三个元素的元组,分别表示图像的高度、宽度和颜色通道数(对于BGR图像,通道数为3)。如果图像是灰度图,则只包含两个元素:高度和宽度。

  • 说明:这一步有助于了解图像的尺寸和是否成功加载(如果imageNone,尝试访问.shape会引发错误)。

4. cv2.imshow("image", image)

  • 作用:在一个窗口中显示图像。窗口的标题由第一个参数指定,图像数据由第二个参数提供。

  • 函数格式cv2.imshow(winname, mat)

    • winname:窗口的名称,是一个字符串。

    • mat:要显示的图像。它应该是uint8或float32类型的numpy数组。

5. cv2.waitKey()

  • 作用:等待用户按键。这个调用是必需的,以便cv2.imshow()创建的窗口能够保持打开状态,直到用户按下任意键。

  • 函数格式cv2.waitKey([delay])

    • delay(可选):等待键盘事件的时间(以毫秒为单位)。如果参数是0,则无限期等待键盘事件。

注意:在程序结束时,通常还需要调用cv2.destroyAllWindows()来关闭所有OpenCV创建的窗口。这虽然不是这段代码的一部分,但在实际应用中是一个好习惯。

TWO(图像RGB颜色通道与灰色转换):

首先使用cv2.imshow函数分别显示了图像image的蓝色、绿色和红色通道,然后使用cv2.cvtColor函数将图像从BGR颜色空间转换为灰度图像,并显示了转换后的灰度图像。

  1. 显示蓝色通道

    cv2.imshow("blue", image[:, :, 0])

    这行代码显示了图像image的蓝色通道。在BGR颜色空间中,蓝色通道是图像的第三个维度(索引为2,但由于Python索引从0开始,所以是索引0)。但是,这里直接访问image[:, :, 0]实际上是访问了第一个通道,即蓝色通道(这里OPENCV图像是以RGB格式加载的,这通常是正确的,因为OpenCV默认以BGR格式加载图像)。

  2. 显示绿色通道

    cv2.imshow("green", image[:, :, 1])
  3. 显示红色通道

    cv2.imshow("red", image[:, :, 2])
  4. 转换为灰度图像并显示

    gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)
    cv2.imshow("gray", gray)

    这两行代码首先将图像image从BGR颜色空间转换为灰度图像,并将结果存储在变量gray中。cv2.cvtColor函数是OpenCV中用于颜色空间转换的函数,cv2.COLOR_BGR2GRAY是将其从BGR颜色空间转换为灰度颜色空间的转换代码。

THREE(图像截取):

使用Python的切片操作来从原始图像image中裁剪出一个区域,并将这个裁剪后的区域存储在变量crop中。然后使用cv2.imshow函数来显示这个裁剪后的图像。

# 从原始图像中裁剪出一个区域
# image[y_start:y_end, x_start:x_end]
# 其中,y_start和x_start是裁剪区域左上角的坐标(包含),y_end和x_end是裁剪区域右下角的坐标(不包含)
crop = image[10:170, 40:200]
# 使用OpenCV的imshow函数显示裁剪后的图像
cv2.imshow("crop", crop)

FOUR(创建图形【方形圆形字体】):

使用了OpenCV库(通过import cv2)和NumPy库(通过import numpy as np)来创建一个黑色的图像,并在该图像上绘制了一条线、一个矩形、一个圆和一段文本。

  1. 创建黑色图像

    image = np.zeros([300, 300, 3], dtype=np.uint8)

    使用NumPy的zeros函数创建一个300x300像素的黑色图像(因为所有像素的RGB值都被初始化为0)。这是一个三维数组,其中前两个维度代表图像的高度和宽度,第三个维度代表颜色通道(RGB)。dtype=np.uint8指定了数组的数据类型为无符号8位整数,这是图像数据常用的数据类型。

  2. 绘制线条

    cv2.line(image, (100, 200), (250, 250), (255, 0, 0), 2)

    使用cv2.line函数在图像上绘制一条从点(100, 200)到点(250, 250)的红色(BGR格式中的(255, 0, 0))线条,线条的厚度为2。

  3. 绘制矩形

    cv2.rectangle(image, (30, 100), (60, 150), (0, 255, 0), 2)

    使用cv2.rectangle函数在图像上绘制一个左上角为(30, 100),右下角为(60, 150)的绿色(BGR格式中的(0, 255, 0))矩形,矩形的边框厚度为2。

  4. 绘制圆

    cv2.circle(image, (150, 100), 20, (0, 0, 255), 3)

    使用cv2.circle函数在图像上绘制一个圆心为(150, 100),半径为20的蓝色(BGR格式中的(0, 0, 255))圆,圆的边框厚度为3。

  5. 添加文本

    cv2.putText(image, "hello", (100, 50), 0, 1, (255, 255, 255), 2, 1)

    使用cv2.putText函数在图像上添加文本“hello”。文本的左下角位于点(100, 50),字体类型为0(OpenCV内置字体之一),字体缩放比例为1,颜色为白色(BGR格式中的(255, 255, 255)),线条厚度为2。最后一个参数1指定了线条类型(用于指定字体是否加粗等,但在这个上下文中,它主要影响文本的渲染方式。lineType线条的类型,如 cv2.LINE_8cv2.LINE_AA 等。对于文本来说,这个参数通常不重要,因为文本绘制有其自己的抗锯齿处理)。

FIVE(图像滤波):

分别应用高斯模糊(Gaussian Blur)和中值模糊(Median Blur)两种滤波技术,并显示原始图像和两种模糊处理后的图像。

有一点需要注意:在调用cv2.waitKey()时,最好指定一个参数(通常是0),这样程序就会等待用户按键后再继续执行。虽然不指定参数在某些环境中可能也能正常工作,但明确指定参数是一个好习惯,可以避免潜在的混淆。

# 检查图像是否成功读取
if image is None:
print("Error: Image could not be read.")
else:
# 应用高斯模糊,

(5, 5): 这是一个元组,指定了高斯核的大小。核的大小是模糊的主要参数之一,较大的核会导致更强烈的模糊效果。

0: 这个参数是高斯核在X和Y方向上的标准差。如果您将此参数设置为0,则函数会根据核的大小自动计算一个合适的标准差。标准差越大,模糊效果越明显。

gauss = cv2.GaussianBlur(image, (5, 5), 0)

# 应用中值模糊

5:这是一个整数,指定了中值滤波器的邻域大小。它必须是正奇数。在这个例子中,滤波器的大小是5x5。中值滤波器用邻域内像素的中位数来替换中心像素的值,这对于去除椒盐噪声(salt-and-pepper noise)特别有效。

median = cv2.medianBlur(image, 5)

SIX(检测角点):

使用了OpenCV库来检测图像中的角点,并在原始图像上标记这些角点。

  1. 转换为灰度图像

    gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)

    使用cv2.cvtColor()函数将原始图像从BGR颜色空间转换为灰度图像。这是因为角点检测通常在灰度图像上进行,以减少计算量并简化问题。

  2. 检测角点

    corners = cv2.goodFeaturesToTrack(gray, 500, 0.1, 10)

    使用cv2.goodFeaturesToTrack()函数在灰度图像上检测角点。这个函数的参数包括:

    corners是一个包含角点坐标的数组,每个角点是一个(x, y)坐标的浮点数对。

    • gray: 输入的灰度图像。
    • 500: 最多要返回的角点数量。注意,实际返回的角点数量可能少于这个值,具体取决于图像和其他参数。
    • 0.1: 角点检测的质量级别,一个介于0到1之间的值,值越低,检测到的角点越多。
    • 10: 最小角点之间的欧氏距离,以像素为单位。这有助于避免检测到的角点过于集中。
  3. 在图像上标记角点

    for corner in corners:
    x, y = corner.ravel()
    cv2.circle(image, (int(x), int(y)), 3, (255, 0, 255), -1)

    遍历检测到的角点,并使用cv2.circle()函数在原始图像上以每个角点为中心绘制一个圆。这里,corner.ravel()用于将角点坐标(通常是一个二维数组)转换为一维数组,从而可以分别访问xy坐标。圆的半径设置为3,颜色设置为粉红色((255, 0, 255)),-1表示圆将被填充。

SEVEN(匹配查找):

用于在一张图片中查找与给定模板相匹配的区域,并在原始图像上绘制这些区域的边界框。

  1. 模板匹配结果的索引:在np.where(match >= 0.9)中,返回的locations是一个元组,其中包含了满足条件的坐标的索引。由于match是一个二维数组,locations将有两个元素,分别对应yx坐标的索引。但是,由于OpenCV的坐标系统通常使用(x, y)格式,您可能需要调整这些索引以正确映射到图像坐标。

# 转换为灰度图像
gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)
# 定义模板
template = gray[75:105, 235:265]
if template.size == 0:
print("Error: Template has zero size.")
exit()
# 执行模板匹配
match = cv2.matchTemplate(gray, template, cv2.TM_CCOEFF_NORMED)
# 找到匹配位置
threshold = 0.9
locations = np.where(match >= threshold)
  1. w, h = template.shape[0:2]:
    • 这行代码从模板图像的shape属性中获取模板的宽度(w)和高度(h)。template.shape返回一个元组,通常包含三个元素(对于二维图像,第三个元素是颜色通道数,但在这里因为是灰度图,所以只有一个颜色通道,且我们不需要它)。通过[0:2]切片,我们选取了前两个元素,即图像的高度和宽度,并将它们分别赋值给hw
  2. for p in zip(*locations[::-1])::
    • locations = np.where(match >= threshold)这行代码生成了一个包含两个数组的元组,这两个数组分别表示满足匹配阈值条件的y(行索引)和x(列索引)坐标的索引。
    • locations[::-1]将这两个数组的顺序反转,因为np.where默认返回的是(y_indices, x_indices),而OpenCV中的坐标系统是(x, y)。通过反转,我们得到(x_indices, y_indices)
    • zip(*locations[::-1])将这两个索引数组“解包”并重新组合成元组的元组,每个内部元组包含一对(x, y)坐标。zip函数在这里实际上是在做“转置”的工作。
    • for p in ...遍历这些(x, y)坐标对。
  3. x1, y1 = p[0], p[1]:
    • 对于每个坐标对p,我们将其分解为x1y1,即矩形边界框的左上角坐标。
  4. x2, y2 = x1 + w, y1 + h:
    • 计算矩形边界框的右下角坐标。通过将左上角坐标x1y1分别加上模板的宽度w和高度h,我们得到边界框的右下角坐标x2y2
  5. cv2.rectangle(image, (x1, y1), (x2, y2), (0, 255, 0), 2):
    • 使用cv2.rectangle函数在原始图像image上绘制一个矩形。参数(x1, y1)(x2, y2)定义了矩形的左上角和右下角坐标。
    • 参数(0, 255, 0)定义了矩形的颜色,这里是绿色(BGR格式)。
    • 最后一个参数2定义了矩形边界的线条粗细。

EIGHT(读取灰度图):

从同一张图像中读取灰度图,然后分别应用拉普拉斯边缘检测和Canny边缘检测。但是,有一点需要注意,当您使用 cv2.Laplacian() 函数时,如果图像是8位无符号整数(即 np.uint8 类型),并且您指定了 cv2.CV_64F 作为输出图像的深度,那么返回的 laplacian 图像将是一个浮点数数组,其值可能超出标准8位图像的显示范围(即0到255)。

为了正确显示 laplacian 图像,您可能需要将其数据类型转换回 np.uint8 并进行归一化或截断到适当的范围。然而,对于可视化目的,简单的归一化到0-255范围并转换为 np.uint8 通常就足够了。

# 读取图像为灰度图
gray = cv2.imread("opencv_logo.jpg", cv2.IMREAD_GRAYSCALE)
# 应用拉普拉斯边缘检测
laplacian = cv2.Laplacian(gray, cv2.CV_64F)
# 将拉普拉斯图像归一化到0-255范围并转换为uint8
laplacian = np.uint8(np.absolute(laplacian / np.max(laplacian)) * 255)
# 应用Canny边缘检测
canny = cv2.Canny(gray, 100, 200)

注意关键点:

  1. 我使用了 np.absolute() 来确保所有值都是非负的,因为拉普拉斯算子可能会产生负值。
  2. 我使用了 np.max(laplacian) 来找到拉普拉斯图像中的最大值,并将其用作归一化的除数。这样,拉普拉斯图像中的所有值都将被缩放到0到255的范围内。

NiNE(阈值处理):

使用了全局阈值处理(固定阈值和Otsu阈值)、以及自适应阈值处理。

  1. 读取灰度图像

    gray = cv2.imread("bookpage.jpg", cv2.IMREAD_GRAYSCALE)

    这行代码读取名为"bookpage.jpg"的图像文件,并将其转换为灰度图像。

  2. 全局固定阈值处理

    ret, binary = cv2.threshold(gray, 10, 255, cv2.THRESH_BINARY)

    这里,您使用了一个固定的阈值(10)来将灰度图像转换为二值图像。所有灰度值大于10的像素点被设置为255(白色),其余被设置为0(黑色)。ret是实际使用的阈值(在这种情况下,它应该是您指定的10,但可能会因为图像数据类型或内部处理而略有不同)。

  3. 自适应阈值处理

    binary_adaptive = cv2.adaptiveThreshold(
    gray, 255, cv2.ADAPTIVE_THRESH_GAUSSIAN_C, cv2.THRESH_BINARY, 115, 1)

    自适应阈值处理会根据图像中每个像素周围的局部区域来计算阈值。这里,您使用了高斯加权和(cv2.ADAPTIVE_THRESH_GAUSSIAN_C),这意味着在计算阈值时,每个像素的邻域将被高斯加权。115是常数,从每个像素的加权平均值中减去以得到最终的阈值。1表示邻域的大小(在这个例子中,它实际上指定了11x11的邻域大小,因为OpenCV中邻域大小是奇数且由参数值加1得到)。

  4. Otsu阈值处理

    ret1, binary_otsu = cv2.threshold(gray, 0, 255, cv2.THRESH_BINARY + cv2.THRESH_OTSU)

    Otsu阈值处理是一种自动选择最佳阈值的方法,用于将图像分割为前景和背景。这里,您通过添加cv2.THRESH_OTSU标志来告诉cv2.threshold函数自动计算最佳阈值。0作为阈值参数在这里被忽略,因为Otsu方法会覆盖它。ret1将包含计算出的最佳阈值。

TEN(腐蚀与膨胀):

import cv2 # 导入OpenCV库,这是一个用于图像处理和计算机视觉的强大库。
import numpy as np # 导入NumPy库,这是一个用于科学计算的基础库,提供了高性能的多维数组对象和相关工具。
# 使用OpenCV的imread函数读取名为"opencv_logo.jpg"的图像文件,并指定以灰度模式读取(cv2.IMREAD_GRAYSCALE)。
# 这将返回一个灰度图像,其中每个像素的亮度值范围是0到255。
gray = cv2.imread("opencv_logo.jpg", cv2.IMREAD_GRAYSCALE)
# 使用OpenCV的threshold函数对灰度图像进行二值化处理。
# 参数gray是源图像,200是阈值,255是当像素值超过阈值时应该赋予的新值(对于THRESH_BINARY_INV类型)。
# cv2.THRESH_BINARY_INV是阈值类型,表示进行反二值化操作,即大于阈值的像素被设置为0(黑色),小于或等于阈值的像素被设置为255(白色)。
# 函数返回两个值,第一个值(通常不关心)是实际使用的阈值(可能由于自动阈值选择算法而略有不同),第二个值是二值化后的图像。
_, binary = cv2.threshold(gray, 200, 255, cv2.THRESH_BINARY_INV)
# 使用NumPy的ones函数创建一个5x5的二维数组,数组中的每个元素都是1,数据类型为无符号8位整数(np.uint8)。
# 这个数组将用作形态学操作(如腐蚀和膨胀)中的结构元素或核。
kernel = np.ones((5, 5), np.uint8)
# 使用OpenCV的erode函数对二值图像进行腐蚀操作。
# 参数binary是输入图像,kernel是前面创建的结构元素。
# 腐蚀操作会使图像中的前景对象(白色区域)变小,通常用于去除小的噪点或分离连接的对象。
erosion = cv2.erode(binary, kernel)
# 使用OpenCV的dilate函数对二值图像进行膨胀操作。
# 参数和腐蚀操作相同,但膨胀操作会使图像中的前景对象(白色区域)变大,通常用于填补前景对象中的小洞或连接相邻的对象。
dilation = cv2.dilate(binary, kernel)

ELEVEN(图像捕获):

用于从计算机的默认摄像头捕获视频流,并在一个窗口中实时显示这些视频帧。

# 初始化视频捕获对象,参数0通常代表计算机的默认摄像头
capture = cv2.VideoCapture(0)
# 使用一个无限循环来持续捕获视频帧
while True:
# capture.read()方法捕获视频帧
# 它返回两个值:
# ret是一个布尔值,如果读取帧成功则为True,如果文件结束或发生错误则为False
# frame是捕获的帧图像
ret, frame = capture.read()
# 如果正确读取了帧,ret为True
if ret:
# 显示捕获的帧
cv2.imshow("camera", frame)
# cv2.waitKey(1)等待1毫秒,检查是否有键盘事件
# 如果用户按下了键,则返回按键的ASCII码;如果没有按键,则返回-1
key = cv2.waitKey(1)
# 如果用户按下了任意键(key不等于-1),则退出循环
if key != -1:
break
# 释放视频捕获对象
capture.release()

注意,我在代码中添加了对ret的检查。这是一个好习惯,因为它可以防止在无法从摄像头读取帧(例如,如果摄像头被断开)时显示空窗口或引发错误。

相关文章:

30min 的OpenCV learning Note

1.安装python和pycharm与环境搭配 打开Windows终端:(winR)(一般使用清华镜像网站安装库比较快) pip install opencv-contrib-python -i https://pypi.mirrors.ustc.edu.cn/simple 或者 python -m pip install open…...

C--编译和链接见解

欢迎各位看官!如果您觉得这篇文章对您有帮助的话 欢迎您分享给更多人哦 感谢大家的点赞收藏评论 感谢各位看官的支持!!! 一:翻译环境和运行环境 在ANSIIC的任何一种实现中,存在两个不同的环境1,…...

【QT Quick】基础语法:基础类与控件

QML 的基础类和控件中,我们可以看到主要的几个分类:基础控件类、窗口类以及组件类。以下是对这些控件及其属性、继承关系等的详细讲解: 控件关系总结 QtObject 是所有 QML 对象的基类。它定义了基础属性,主要用于逻辑和数据封装…...

使用 SSH 连接 Docker 服务器:IntelliJ IDEA 高效配置与操作指南

使用 SSH 连接 Docker 服务器:IntelliJ IDEA 高效配置与操作指南 本文详细介绍了如何在 2375 端口未开放的情况下,通过 SSH 连接 Docker 服务器并在 Idea 中进行开发。通过修改用户权限、生成密钥对以及配置 SSH 访问,用户可以安全地远程操作…...

Gas费用是什么?

Gas费用是什么? 每5个Byte 需要1个GasGasLimit 用来限制合约最多执行多少次运算GasPrice 每次计算需要支付的费用在Web3的语境中,尤其是在以太坊(Ethereum)这样的区块链平台上,Gas费是一个核心概念。以下是关于Gas费的详细解释: 1. 定义 Gas是以太坊网络上的计算单位,…...

大语言模型(LLM)的子模块拆拆分进行联邦学习;大语言模型按照多头(Multi-Head)拆分进行联邦学习

目录 大语言模型(LLM)的子模块拆拆分进行联邦学习 方式概述 简单示例 大语言模型按照多头(Multi-Head)拆分进行联邦学习 场景设定 多头拆分与联邦学习 示例说明 大语言模型(LLM)的子模块拆拆分进行联邦学习 大语言模型(LLM)的子模块拆分进行联邦学习,主要涉及…...

Qt 概述

1. Qlabel HelloWorld 程序 使用纯代码实现 // widget.cpp Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget) {ui->setupUi(this);// 给当前这个lable对象,指定一个父对象QLabel* label new QLabel(this);// C语言风格的字符串可以直接…...

移动应用的界面配置-手机银行APP

设置登录界面为线性布局,组件垂直居中排列设置主页为滚动模式,包括布局、添加背景图片设置按钮样式,包括形状、边框线的宽度和颜色 设置登录界面 设置界面为线性布局,组件垂直居中排列 --android:gravity"center_vertical…...

微服务nginx解析部署使用全流程

目录 1、nginx介绍 1、简介 2、反向代理 3、负载均衡 2、安装nginx 1、下载nginx 2、解压nginx安装包 3、安装nginx​编辑 1、执行configure命令 2、执行make命令 4、启动nginx 1、查找nginx位置并启动 2、常用命令 3、反向代理 1、介绍反向代理配置 1、基础配置…...

华硕天选笔记本外接音箱没有声音

系列文章目录 文章目录 系列文章目录一.前言二.解决方法第一种方法第二种方法 一.前言 华硕天选笔记本外接音箱没有声音,在插上外接音箱时,系统会自动弹出下图窗口 二.解决方法 第一种方法 在我的电脑上选择 Headphone Speaker Out Headset 这三个选项…...

Unity中Socket_TCP异步连接,加入断线检测以及重连功能

1、服务端 using System; using System.Collections.Generic; using System.Text; #region 命名空间 using System.Net; using System.Net.Sockets; using System.Threading; using UnityEngine; #endregionnamespace AsynServerConsole {/// <summary>/// Tcp协议异步通…...

Android build子系统(01)Ninja构建系统解读

说明&#xff1a;本文将解读Ninja构建系统&#xff0c;这是当前Android Framework中广泛使用的构建工具。我们将从Ninja的起源和背景信息开始&#xff0c;逐步解读Ninja的优势和核心原理&#xff0c;并探讨其一般使用场景。然后介绍其在Android Framework中的应用及相关工具&am…...

徐老师的吉祥数

题目背景 文件读写 输入文件avoid.in 输出文件avoid.out 限制 1000ms 512MB 题目描述 众所周知&#xff0c; 3这个数字在有些时候不是很吉利&#xff0c;因为它谐音为 “散” 所以徐老师认为只要是 3的整数次幂的数字就不吉利 现在徐老师想知道&#xff0c;在某个范围[l,r] …...

使用html写一个能发起请求的登录界面

目录 head部分 内联样式部分 body部分 login-form类的div myModal类的div id script部分 总的代码 界面与操作演示 <!DOCTYPE html> <html lang"en"> <!DOCTYPE html> 这是文档类型声明&#xff0c;告诉浏览器这是一个 HTML文档。 <…...

五子棋双人对战项目(2)——登录模块

目录 一、数据库模块 1、创建数据库 2、使用MyBatis连接并操作数据库 编写后端数据库代码 二、约定前后端交互接口 三、后端代码编写 文件路径如下&#xff1a; UserAPI&#xff1a; UserMapper&#xff1a; 四、前端代码 登录页面 login.html&#xff1a; 注册页面…...

几种操作系统和几种cpu

常见的操作系统&#xff1a;windows&#xff0c;linux&#xff0c;macOS&#xff0c;统信&#xff0c;deepin&#xff0c;raspberry&#xff0c;andriod&#xff0c;iOS&#xff0c;鸿蒙&#xff0c;等等。 常见的cpu&#xff1a;intel&#xff0c;amd&#xff0c;龙芯&#x…...

[Cocoa]_[初级]_[使用NSNotificationCenter作为目标观察者实现时需要注意的事项]

场景 在开发Cocoa程序时&#xff0c;由于界面是用Objective-C写的。无法使用C的目标观察者[1]类。如果是使用第二种方案2[2],那么也需要增加一个代理类。那么有没有更省事的办法&#xff1f; 说明 开发界面的时候&#xff0c;经常是需要在子界面里传递数据给主界面&#xff0…...

彩虹易支付最新版源码及安装教程(修复BUG+新增加订单投诉功能)

该源码当前版本为较新的版本&#xff0c;新增了订单投诉功能和一套精美的二次元模板。 此版本为全开源版本&#xff0c;所有文件均未加密。系统默认安装完成后无法直接打开&#xff0c;需要进一步配置。 本站特别针对BUG文件进行了修复&#xff0c;且在PHP7.4环境下表现良好。…...

ping香港服务器超时的原因通常有哪些?

Ping命令用于测试计算机与目标服务器之间的网络连接。当您在尝试使用ping命令检测服务器时遇到超时的情况&#xff0c;通常可能是由以下原因造成的&#xff1a; 1. 网络连接问题&#xff1a; - 本地网络故障&#xff1a;如网线损坏、路由器故障或配置不当。 - ISP(互联网服务提…...

书生大模型实战(从入门到进阶)L3-彩蛋岛-InternLM 1.8B 模型 Android 端侧部署实践

目录 1 环境准备 1.1 安装rust 1.2 安装Android Studio 1.3 设置环境变量 2 转换模型 2.1 安装mlc-llm 2.2 (可选)转换参数 2.3 (可选)生成配置 2.4 (可选)上传到huggingface 2.5 (可选) 测试转换的模型 3 打包运行 3.1 修改配置文件 3.2 运行打包命令 3.3 创建签…...

setState是同步更新还是异步更新

setState是同步更新还是异步更新 先说结论setState为什么设计为异步react18之前为什么不确定是同步还是异步呢react18之后setState有哪些改动 先说结论 React18之前&#xff1a;使用了ReactDOM.render&#xff0c;setState在React调度流程中是异步更新&#xff0c;在原生事件和…...

TCP 流量控制 - 滑动窗口和拥塞控制算法解析

滑动窗口主要管理数据流动的速率&#xff0c;对单个连接较好&#xff0c;拥塞控制则防止网络出现过载&#xff0c;对提高整体的网络通畅较好。下面详细解析两者的原理和作用。 1. TCP 滑动窗口算法 TCP 使用滑动窗口机制来控制数据的发送和接收&#xff0c;以实现流量控制&…...

MongoDB聚合操作及索引底层原理

目录 链接:https://note.youdao.com/ynoteshare/index.html?id=50fdb657a9b06950fa255a82555b44a6&type=note&_time=1727951783296 本节课的内容: 聚合操作: 聚合管道操作: ​编辑 $match 进行文档筛选 ​编辑 将筛选和投影结合使用: ​编辑 多条件匹配: …...

C++ | Leetcode C++题解之第454题四数相加II

题目&#xff1a; 题解&#xff1a; class Solution { public:int fourSumCount(vector<int>& A, vector<int>& B, vector<int>& C, vector<int>& D) {unordered_map<int, int> countAB;for (int u: A) {for (int v: B) {count…...

【从零开始实现stm32无刷电机FOC】【实践】【7.2/7 完整代码编写】

目录 stm32cubemx配置芯片选择工程配置stm32基础配置SPI的配置定时器的配置ADC的配置中断优先级的配置生成工程 工程代码编写FOC代码结构搭建电机编码器角度读取PWM产生FOC开环代码编写确定电机正负旋转方向电机旋转速度计算多圈逻辑角度电流采样极对数转子角度确定 闭环控制控…...

谷歌收录查询工具,谷歌收录查询工具的使用指南

谷歌收录查询工具是网站管理员和SEO专业人士用于检查网站是否被谷歌搜索引擎收录及其收录情况的重要辅助手段。以下是一些常用的谷歌收录查询工具及其详细使用指南&#xff1a; 一、Google Search Console&#xff08;谷歌搜索控制台&#xff09; 简介&#xff1a; Google Sea…...

vue3 拖拽插件(drag)

前端vue项目中&#xff0c;经常会有弹框拖拽的需求&#xff0c;下面介绍常用方法&#xff1a; 1.如果你使用的是elementPlus插件的el-dialog组件,只需要增加draggable属性即可&#xff0c;代码如下&#xff1a; <el-dialogv-model"showDiloag"width"500&quo…...

数据结构--线性表(顺序结构)

1.线性表的定义和基本操作 1.1线性表以及基本逻辑 1.1.1线性表 &#xff08;1&#xff09;n(>0)个数据元素的有限序列&#xff0c;记作&#xff08;a1,a2,...an&#xff09;&#xff0c;其中ai是线性表中的数据元素&#xff0c;n是表的长度。 &#xff08;2&#xff09;…...

面试准备111

Java基础 反射 集合 多线程 Synchronized/volatile 线程池 cas atomic 网络 tcp 三次握手/四次挥手 流量控制 拥塞控制 数据结构 算法 Spring 循环依赖 Mybatis 如何防止sql注入 Mysql 索引 索引分类 索引设计原则 事务 四种隔离级别 MVCC 日志 Binlog…...

Spring 的 IOC 和 AOP 是什么,有哪些优点?解密 Spring两大核心概念:IOC与AOP的魅力所在

在现代Java开发中&#xff0c;Spring框架几乎是不可或缺的存在。它不仅简化了开发过程&#xff0c;还提高了软件的灵活性和可维护性。今天&#xff0c;我们要深入探讨Spring中的两个核心概念&#xff1a;IOC&#xff08;控制反转&#xff09;和AOP&#xff08;面向切面编程&…...

大连网站建设特色/seo性能优化

又到了年末&#xff0c;今年的年终总结我考虑了很久&#xff0c;到底要不要写&#xff1f;可以写些什么&#xff1f; 今年过得十分匆忙&#xff0c;我一直在赶路&#xff0c;但事实上今年内做完的&#xff0c;能说出口的事可以说没有。 回顾下去年对今年的期望&#xff1a; 有…...

网站建设师要求/谷歌地球

首先可以打开朋友圈观察不同图片数量的几种布局,也可参考下图示例&#xff1b;可以发现除1张图片&#xff0c;4张图片特殊外&#xff0c;其他数量图片均使用一行三列的方式排列&#xff1b;假设有如下HTML代码&#xff0c;这里imgList是一个图片地址数组&#xff1b;1、首先我们…...

北京怀柔做网站管理运营的公司/温州seo公司

2019独角兽企业重金招聘Python工程师标准>>> 在 iOS 开发中有时候因为疏忽或者误操作导致上面的错误出现,那么解决办法其实很简单,下面来给大家一步步的叙述: 首先想跟大家说一下,这个问题的原因就是因为连线的原因,比如连线找不到,连线的代码被误操作注释掉等,通常…...

兰州网站设计/应用商店下载

一家名为Firewall Leak Tester的个人防火墙软件开发公司推出首个专门屏蔽微软正版验证程序WGA“给微软家里打电话”的工具软件&#xff0d;&#xff0d;RemoveWGA。 “一旦微软的WGA认证工具确定你使用的是正版Windows&#xff0c;微软就再没有理由接连将你的计算机信息传给微…...

二级域名网址查询/长春百度关键词优化

<script language"javascript" type"text/javascript">var ReTitle 回复:评论:个人宽带:除了下载、盗版还剩下什么;</script> 感谢中国读者网的投递你怎么看待自己家里的宽带?消遣的工具?娱乐的平台?资源获取的渠道?工作的必备?的确,个人…...

网站建设与运营策划书/简述搜索引擎优化的方法

在 Markdown 中&#xff0c;可以使用3个以上的 *、-或者_来实现一个分隔线。 语法规则&#xff1a; ***或---或___分隔线至少使用3个 *、-或者_。行内可以加空格&#xff0c;即使加在*/-/_之间也没问题。行内不能出现其他字符。 示例&#xff1a; 我是第一段。下面使用星号…...