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

可靠的网站建设图/自己怎样推广呢

可靠的网站建设图,自己怎样推广呢,网站权重为零,用模板做网站的方法DMA的介绍与使用 1、DMA简介2、存储器映像3、DMA框图4、DMA基本结构5、DMA请求6、数据宽度与对齐7、数据转运DMA(存储器到存储器的数据转运)程序编写: 8、ADC连续扫描模式DMA循环转运DMA配置:程序编写: 1、DMA简介 DM…

DMA的介绍与使用

  • 1、DMA简介
  • 2、存储器映像
  • 3、DMA框图
  • 4、DMA基本结构
  • 5、DMA请求
  • 6、数据宽度与对齐
  • 7、数据转运+DMA(存储器到存储器的数据转运)
    • 程序编写:
  • 8、ADC连续扫描模式+DMA循环转运
    • DMA配置:
    • 程序编写:

1、DMA简介

  • DMA(Direct Memory Access)直接存储器存取
    • 可以直接访问STM32内部存储器,包括运行内存SRAM、程序存储器Flash和寄存器等
  • DMA可以提供外设和存储器或者存储器和存储器之间的高速数据传输,无须CPU干预,节省了CPU的资源
    • 外设:指的是外设寄存器(一般是外设数据寄存器DR,如ADC的数据寄存器、串口的数据寄存器)
    • 存储器:指运行内存SRAM和程序存储器Flash(存储变量数组和程序代码)
  • 12个独立可配置的通道: DMA1(7个通道), DMA2(5个通道)
  • 每个通道都支持软件触发和特定的硬件触发
    • 软件触发:一般使用存储器到存储器
    • 硬件触发:一般使用外设到存储器
  • STM32F103C8T6 DMA资源:DMA1(7个通道)

2、存储器映像

在这里插入图片描述
计算机系统的5大组成部分:运算器、控制器、存储器、输入设备和输出设备
运算器、控制器统称为CPU

3、DMA框图

在这里插入图片描述

  • DMA总线:用于访问各个存储器,内部多个通道,可以进行独立的数据转运
  • 仲裁器:用于调度各个通道,防止产生冲突
  • AHB从设备:用于配置DMA参数
  • DMA请求:用于硬件触发DMA的数据转运

4、DMA基本结构

在这里插入图片描述

  • 起始地址:外设端的起始地址和存储器端的起始地址(决定数据的方向)
  • 数据宽度:指定一次转运要按多大的数据宽度来进行(字节Byte[8位]、半字HalfWord[16位]和字Word[32位])
  • 地址是否自增:指定一次转运完成后,下一次转运,是不是要把地址移动到下一个位置去
  • 传输计数器:自减计数器,计数器值即DMA转运的次数 ,减到0后,自增的地址会恢复到起始地址的位置,以方便之后DMA开始新一轮的转运
  • 自动重装器:决定转运的模式,不重装为单次模式,重装为循环模式
    • 传输计数器减到0之后,是否要自动恢复到最初的值,如传输计数器值为5,如果不使用自动重装器,转运5次后,DMA转运结束,如果使用自动重装器,转运5次,计数器减到0后,会立即重装到初始值5,DMA再次开始转运数据
  • 触发控制:决定DMA需要在什么时机进行转运。
    • M2M(Memory to Memory)决定选择哪个触发源,M2M = 1,DMA选择软件触发(ps:软件触发和循环模式不能同时使用,因为软件触发就是把传输计数器清零,循环模式是清零后自动重装,如果同时使用,DMA无法停止);M2M = 0,DMA选择硬件触发(ADC,串口,定时器),硬件触发的转运,一般都与外设有关的转运,这些转运需要一定的时机,比如ADC转换完成、串口收到数据、定时时间到等,在硬件达到这些时机时,传一个信号过来,触发DMA进行转运。
  • 开关控制:调用DMA_Cmd函数,当给DMA使能后,DMA准备就绪,可以进行转运
    • DMA可以转运的条件:1、开关控制,DMA_Cmd必须使能;2、传输计数器必须大于0;3、触发源,必须有触发信号

注意:写传输计数器时,必须要先关闭DMA,再进行

5、DMA请求

在这里插入图片描述
DMA触发部分:
EN位:EN=0,数据选择器不工作,EN=1,数据选择器工作
软件触发后面跟个M2M位的意思:当M2M位=1时,选择软件触发

PS:想使用某个硬件触发源,必须使用它所在的通道;使用软件触发,通道可以任意选择

6、数据宽度与对齐

在这里插入图片描述
源端宽度比目标宽度小时:

  • 当源端和目标都是8位时,转运第一步,在源端的0位置,读数据B0,在自标的0位置,写数据B0,即把B0,从左边挪到右边,后续B1,B2,B3同理;
  • 当源端是8位,目标是16位,在源端读B0,在目标写00B0,之后,读B1,写00B1等,后续同理
    • 总结:若目标的数据宽度比源端的数据宽度大,在目标数据前面多出来的空位补0
  • 当源端是8位,目标是32位,同源端8位,目标16位处理方式相同

源端宽度比目标宽度大时:

  • 当源端是16位,目标是8位,读B1BO,只写入B0;读B3B2,只写入B2,
    • 总结:将高位舍弃
  • 其它方式依次类推

7、数据转运+DMA(存储器到存储器的数据转运)

在这里插入图片描述

将SRAM里的数组DataA,转运到另一个数组DataB中

  • 外设地址:DataA数组首地址 | 存储器地址:DataB数组的首地址
  • 数据宽度:两个数组的类型都是uint8_t,按8位的字节传输
  • 地址自增:数组DataA和DataB均自增
  • 转运方向:存储器向存储器转运
  • 传输计数器;转运7次,自动重装器不使用
  • 触发控制:软件触发

程序编写:

// myDMA.c
#include "stm32f10x.h"                  // Device header
/*
DMA 转运的3个条件
1、传输计数器大于0      Size > 0
2、触发源有触发信号 
3、DMA使能
*/uint16_t MyDMA_Size;void MyDMA_Init(uint32_t AddrA, uint32_t AddrB, uint16_t Size)
{MyDMA_Size = Size;// 开启DMA时钟RCC_AHBPeriphClockCmd(RCC_AHBPeriph_DMA1, ENABLE);DMA_InitTypeDef DMA_InitStructure;DMA_InitStructure.DMA_PeripheralBaseAddr = AddrA;// 外设起始地址DMA_InitStructure.DMA_PeripheralDataSize = DMA_PeripheralDataSize_Byte;// 外设数据宽度--以字节方式传输DMA_InitStructure.DMA_PeripheralInc = DMA_PeripheralInc_Enable; // 外设地址是否自增--自增DMA_InitStructure.DMA_MemoryBaseAddr = AddrB;                      // 存储器起始地址DMA_InitStructure.DMA_MemoryDataSize = DMA_MemoryDataSize_Byte; // 存储器数据宽度--以字节方式传输DMA_InitStructure.DMA_MemoryInc = DMA_MemoryInc_Enable;         // 存储器地址是否自增--自增DMA_InitStructure.DMA_DIR = DMA_DIR_PeripheralSRC;              // 传输方向--外设站点到存储器站点DMA_InitStructure.DMA_BufferSize = Size;                          // 缓存区大小,也是传输计数器--传输次数DMA_InitStructure.DMA_Mode = DMA_Mode_Normal;                     // 传输模式,是否使用自动重装--不能和软件触发同时使用,选择不自动重装,计数减到0后停止DMA_InitStructure.DMA_M2M = DMA_M2M_Enable;                     // 选择是否是存储器到存储器,即选择硬件触发还是软件触发DMA_InitStructure.DMA_Priority = DMA_Priority_Medium;             // 优先级DMA_Init(DMA1_Channel1, &DMA_InitStructure);DMA_Cmd(DMA1_Channel1, DISABLE); // 初始化不立刻转运,使用MyDMA_Transfer函数进行转运
}
// 调用此函数,再次启动一次DMA转运
void MyDMA_Transfer(void)
{// 重新给传输计数器赋值,先把DMA失能DMA_Cmd(DMA1_Channel1, DISABLE);        // DMA失能DMA_SetCurrDataCounter(DMA1_Channel1, MyDMA_Size); // 传输计数器赋值DMA_Cmd(DMA1_Channel1, ENABLE);     // DMA 使能while (DMA_GetFlagStatus(DMA1_FLAG_TC1) == RESET);// 等待转运完成DMA_ClearFlag(DMA1_FLAG_TC1);// 清除标志位
}
// main.c
#include "stm32f10x.h"                  // Device header
#include "Delay.h"
#include "OLED.h"
#include "MyDMA.h"uint8_t DataA[] = {0x01, 0x02, 0x03, 0x04};
uint8_t DataB[] = {0, 0, 0, 0};int main(void)
{OLED_Init();// DataA地址数据转运到DataB地址MyDMA_Init((uint32_t)DataA, (uint32_t)DataB, 4);OLED_ShowString(1, 1, "DataA");OLED_ShowString(3, 1, "DataB");OLED_ShowHexNum(1, 8, (uint32_t)DataA, 8);OLED_ShowHexNum(3, 8, (uint32_t)DataB, 8);while (1){DataA[0] ++;DataA[1] ++;DataA[2] ++;DataA[3] ++;OLED_ShowHexNum(2, 1, DataA[0], 2);OLED_ShowHexNum(2, 4, DataA[1], 2);OLED_ShowHexNum(2, 7, DataA[2], 2);OLED_ShowHexNum(2, 10, DataA[3], 2);OLED_ShowHexNum(4, 1, DataB[0], 2);OLED_ShowHexNum(4, 4, DataB[1], 2);OLED_ShowHexNum(4, 7, DataB[2], 2);OLED_ShowHexNum(4, 10, DataB[3], 2);Delay_ms(1000);MyDMA_Transfer();OLED_ShowHexNum(2, 1, DataA[0], 2);OLED_ShowHexNum(2, 4, DataA[1], 2);OLED_ShowHexNum(2, 7, DataA[2], 2);OLED_ShowHexNum(2, 10, DataA[3], 2);OLED_ShowHexNum(4, 1, DataB[0], 2);OLED_ShowHexNum(4, 4, DataB[1], 2);OLED_ShowHexNum(4, 7, DataB[2], 2);OLED_ShowHexNum(4, 10, DataB[3], 2);Delay_ms(1000);}
}

8、ADC连续扫描模式+DMA循环转运

在这里插入图片描述

左边为ADC扫描模式的执行流程:7个通道,触发一次后,7个通道依次进行AD转换,转换结果都放到ADC_DR数据寄存器中,需要在每个单独的通道转换完成后,进行一个DMA数据转运,并且目的地址进行自增,防止数据被覆盖。

DMA配置:

  • 外设地址写入ADC_DR寄存器的地址,存储器地址,可以在SRAM中定义一个数组ADValue,把ADValue的地址当做存储器的地址
  • 数据宽度:16位的半字传输
  • 地址是否自增;外设地址不自增,存储器地址自增
  • 传输方向:外设到存储器
  • 传输计数器:通道有7个,计数7次
  • 计数器是否自动重装,看ADC的配置,ADC如果是单次扫描,DMA的传输计数器可以不自动重装,如果ADC是连续扫描,DMA可以使用自动重装,在ADC启动下一轮转换时,DMA也启动下一轮转运,ADC和DMA同步工作
  • 触发选择:ADC_DR的值是在ADC单个通道转换完成后才会有效,所以DMA转运的时机,需要和ADC单个通道转换完成同步,DMA的触发要选择ADC的硬件触发

程序编写:

// AD.c
// 使用软件触发ADC采集数据--->ADC硬件触发DMA转运数据到存储器
#include "stm32f10x.h"                  // Device headeruint16_t AD_Value[4];// ADC连续扫描模式+DMA循环转运
void AD_Init(void)
{RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1, ENABLE);RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE);RCC_AHBPeriphClockCmd(RCC_AHBPeriph_DMA1, ENABLE);RCC_ADCCLKConfig(RCC_PCLK2_Div6);GPIO_InitTypeDef GPIO_InitStructure;GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN;GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0 | GPIO_Pin_1 | GPIO_Pin_2 | GPIO_Pin_3;GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;GPIO_Init(GPIOA, &GPIO_InitStructure);ADC_RegularChannelConfig(ADC1, ADC_Channel_0, 1, ADC_SampleTime_55Cycles5);ADC_RegularChannelConfig(ADC1, ADC_Channel_1, 2, ADC_SampleTime_55Cycles5);ADC_RegularChannelConfig(ADC1, ADC_Channel_2, 3, ADC_SampleTime_55Cycles5);ADC_RegularChannelConfig(ADC1, ADC_Channel_3, 4, ADC_SampleTime_55Cycles5);ADC_InitTypeDef ADC_InitStructure;ADC_InitStructure.ADC_Mode = ADC_Mode_Independent;ADC_InitStructure.ADC_DataAlign = ADC_DataAlign_Right;ADC_InitStructure.ADC_ExternalTrigConv = ADC_ExternalTrigConv_None;ADC_InitStructure.ADC_ContinuousConvMode = ENABLE; // 连续扫描ADC_InitStructure.ADC_ScanConvMode = ENABLE;  // 使用扫描模式ADC_InitStructure.ADC_NbrOfChannel = 4;ADC_Init(ADC1, &ADC_InitStructure);DMA_InitTypeDef DMA_InitStructure;DMA_InitStructure.DMA_PeripheralBaseAddr = (uint32_t)&ADC1->DR; // ADC DR的基地址,ADC采集到的数据存到此寄存器中DMA_InitStructure.DMA_PeripheralDataSize = DMA_PeripheralDataSize_HalfWord; // 16位DMA_InitStructure.DMA_PeripheralInc = DMA_PeripheralInc_Disable;// 外设地址不需自增DMA_InitStructure.DMA_MemoryBaseAddr = (uint32_t)AD_Value; // 转运数据到的目的地址DMA_InitStructure.DMA_MemoryDataSize = DMA_MemoryDataSize_HalfWord; // 16位DMA_InitStructure.DMA_MemoryInc = DMA_MemoryInc_Enable;  // 存储器地址自增DMA_InitStructure.DMA_DIR = DMA_DIR_PeripheralSRC;DMA_InitStructure.DMA_BufferSize = 4;  //  传输次数-4个ADC通道DMA_InitStructure.DMA_Mode = DMA_Mode_Circular; // 循环模式DMA_InitStructure.DMA_M2M = DMA_M2M_Disable; // 硬件触发DMA_InitStructure.DMA_Priority = DMA_Priority_Medium;DMA_Init(DMA1_Channel1, &DMA_InitStructure); // ADC 硬件触发只在DMA1的通道1上DMA_Cmd(DMA1_Channel1, ENABLE);ADC_DMACmd(ADC1, ENABLE); // 开启ADC到DMA的输出ADC_Cmd(ADC1, ENABLE);ADC_ResetCalibration(ADC1);while (ADC_GetResetCalibrationStatus(ADC1) == SET);ADC_StartCalibration(ADC1);while (ADC_GetCalibrationStatus(ADC1) == SET);ADC_SoftwareStartConvCmd(ADC1, ENABLE);//ADC开始工作
}
//main.c
#include "stm32f10x.h"                  // Device header
#include "Delay.h"
#include "OLED.h"
#include "AD.h"int main(void)
{OLED_Init();AD_Init();OLED_ShowString(1, 1, "AD0:");OLED_ShowString(2, 1, "AD1:");OLED_ShowString(3, 1, "AD2:");OLED_ShowString(4, 1, "AD3:");while (1){OLED_ShowNum(1, 5, AD_Value[0], 4);OLED_ShowNum(2, 5, AD_Value[1], 4);OLED_ShowNum(3, 5, AD_Value[2], 4);OLED_ShowNum(4, 5, AD_Value[3], 4);Delay_ms(100);}
}

相关文章:

【stm32】DMA的介绍与使用

DMA的介绍与使用 1、DMA简介2、存储器映像3、DMA框图4、DMA基本结构5、DMA请求6、数据宽度与对齐7、数据转运DMA(存储器到存储器的数据转运)程序编写: 8、ADC连续扫描模式DMA循环转运DMA配置:程序编写: 1、DMA简介 DM…...

哈希表的魔力

哈希表与字典 普遍存在一种误解,认为“哈希表”和“字典”这两个术语可以互换。这种观念从根本上是不准确的,至少在计算机科学领域是如此。 字典是将键映射到值的数据结构的一般概念。而哈希表是字典的具体实现。 本质上,字典扮演着一个总体…...

《YOLO 目标检测》—— YOLO v3 详细介绍

!!!!!!!!!!!!!还未写完!!!!!!!&#xf…...

WNN 多模态整合 | Seurat 单细胞多组学整合流程

测试环境:CentOS7.9, R4.3.2, Seurat 4.4.0, SeuratObject 4.1.4 2024.10.23 # WNN library(ggplot2) library(dplyr) library(patchwork)1. 导入数据 (1). load counts of RNA and protein dyn.load(/home/wangjl/.local/lib/libhdf5_hl.so.100) library(hdf5r)…...

【Linux】磁盘文件系统(inode)、软硬链接

文章目录 1. 认识磁盘1.1 磁盘的物理结构1.2 磁盘的逻辑结构 2. 引入文件系统2.1 EXT系列文件系统的分区结构2.2 inode 3. 软硬链接3.1 软链接3.2 硬链接 在讲过了内存文件系统后,我们可以知道文件分为两种: 打开的文件(内存中)未…...

网安加·百家讲坛 | 徐一丁:金融机构网络安全合规浅析

作者简介:徐一丁,北京小西牛等保软件有限公司解决方案部总监,网络安全高级顾问。2000年开始从事网络安全工作,主要领域为网络安全法规标准研究、金融行业安全咨询与解决方案设计、信息科技风险管理评估等。对国家网络安全法规标准…...

九、pico+Unity交互开发——触碰抓取

一、VR交互的类型 Hover(悬停) 定义:发起交互的对象停留在可交互对象的交互区域。例如,当手触摸到物品表面(可交互区域)时,视为触发了Hover。 Grab(抓取) 概念&#xff…...

老机MicroServer Gen8再玩 OCP万兆光口+IT直通

手上有一台放了很久的GEN8微型服务器,放了很多年,具体什么时候买的我居然已经记不清了 只记得开始装修的时候搬家出去就没用了,结果搬出去有了第1个孩子,孩子小的时候也没时间折腾,等孩子大一点的时候,又有…...

jmeter 从多个固定字符串中随机取一个值的方法

1、先新增用户参数,将固定值设置为不同的变量 2、使用下面的函数,调用这写变量 ${__RandomFromMultipleVars(noticeType1|noticeType2|noticeType3|noticeType4|noticeType5)} 3、每次请求就是随机取的值了...

priority_queue (优先级队列的使用和模拟实现)

使用 priority_queue 优先级队列与 stack 和 queue 一样,也是一个容器适配器,其底层通过 vector 来实现的。与 stack 和 queue 不同的是,它的第一个元素总是它所包含的元素中最大或最小的一个。 也就是说,优先级队列就是数据结…...

VisionPro 手部骨骼跟踪 Skeletal Hand Tracking 虚拟首饰

骨骼手部跟踪由XR Hands Package中的Hand Subsystem提供。使用场景中的Hand Visualizer组件,用户可以显示玩家手部的蒙皮网格或每个关节的几何图形,以及用于基于手部物理交互的物理对象。用户可以直接针对Hand Subsystem编写 C# 脚本,以推断骨…...

class 9: vue.js 3 组件化基础(2)父子组件间通信

目录 父子组件之间的相互通信父组件传递数据给子组件Prop为字符串类型的数组Prop为对象类型 子组件传递数据给父组件 父子组件之间的相互通信 开发过程中,我们通常会将一个页面拆分成多个组件,然后将这些组件通过组合或者嵌套的方式构建页面。组件的嵌套…...

Laravel|Lumen项目配置信息config原理

介绍 Laravel 框架的所有配置文件都保存在 config 目录中。每个选项都有说明,你可随时查看这些文件并熟悉都有哪些配置选项可供你使用。 使用 您可以在应用程序的任何位置使用全局 config 辅助函数轻松访问配置值。 可以使用“点”语法访问配置值,其中…...

2024系统分析师考试---论区块链技术及其应用

试题三论区块链技术及其应用 区块链作为一种分布式记账技术,目前已经被应用到了资产管理、物联网、医疗管理、政务监管等多个领域,从网络层面来讲,区块链是一个对等网络(Peer to Peer,P2P),网络中的节点地位对等,每个节点都保存完整的账本数据,系统的运行不依赖中心化节…...

为您的 Raspberry Pi 项目选择正确的实时操作系统(RTOS)

在嵌入式系统设计中,实时操作系统(RTOS)的选择对于确保项目的实时性能和可靠性至关重要。Raspberry Pi,尤其是其最新的RP2040微控制器,为开发者提供了一个功能强大的平台来实现各种实时应用。本文将探讨如何为您的Rasp…...

鸿蒙应用的Tabs 组件怎么使用

鸿蒙应用中的Tabs组件是一个用于通过页签进行内容视图切换的容器组件,每个页签对应一个内容视图。以下是Tabs组件的使用方法: 一、基本结构 Tabs组件的页面组成包含两个部分,分别是TabContent和TabBar。TabContent是内容页,TabB…...

第四天 文件操作与异常处理

在Python中,文件操作是处理输入输出的基本操作之一,而异常处理则用于管理潜在的错误情况,确保程序的健壮性和稳定性。下面将介绍Python中的文件操作和异常处理的基本用法。 文件操作 打开文件 使用内置的 open() 函数可以打开一个文件&…...

【密码分析学 笔记】ch3 3.1 差分分析

ch3 分组密码的差分分析和相关分析方法 3.1 差分分析 评估分组密码安全性通用方法可用于杂凑函数和流密码安全性 预备知识: 迭代性分组密码(分组密码一般结构)简化版本 mini-AES CipherFour算法 3.1.1 差分分析原理 现象:密…...

Go:strings包的基本使用

文章目录 string前缀和后缀字符串包含判断子字符串或字符在父字符串中出现的位置字符串替换统计字符串出现次数重复字符串修改字符串大小写修剪字符串分割字符串拼接 slice 到字符串 strconv 本篇主要总结的是go中的string包的一些函数的操作讲解 string 在各个语言中&#x…...

uniapp,获取头部高度

头部自定义时候&#xff0c;设置获取安全区域&#xff0c;可以用 uni.getSystemInfoSync();接口。 <view class"statusBar" :style"{height:statusBarHeightpx}"> let SYSuni.getSystemInfoSync(); let statusBarHeightref(SYS.statusBarHeight) …...

开发面试题-更新中...

探迹科技&#xff08;腾讯面试官&#xff09; 1.了不了解循环屏障 2.对于java中的线程冲突有多少了解&#xff08;我要算1加到1亿&#xff09; 3.mysql调优怎么调&#xff08;我跟他讲了explain&#xff09; 4.type中ref&#xff0c;range,const的区别 5.我有1亿的数据量&…...

【Jmeter】jmeter指定jdk版本启动

背景&#xff1a; 因权限问题&#xff0c;不能修改操作系统的环境变量或者因jmeter启动加载的默认jdk8版本低&#xff0c;需要指定jdk XX版本启动Jmeter 解决办法&#xff1a; 进入jmeter bin目录选择jmeter.bat&#xff0c;记事本编辑jmeter.bat, 在最前面添加 set MINIMAL_…...

数据处理利器:图片识别转Excel表格让数据录入变简单

在现代职场中&#xff0c;手动录入数据是一个耗时且容易出错的过程。无论是纸质文件、照片还是截图&#xff0c;繁琐的输入常常让人感到头疼。如何高效地将这些信息转化为电子表格&#xff0c;是许多职场人士面临的挑战。 为了解决这一问题&#xff0c;我们推出了图片识别转Exc…...

【WPF】中Binding的应用

在 WPF (Windows Presentation Foundation) 中&#xff0c;数据绑定是一种强大的机制&#xff0c;它允许你将用户界面&#xff08;UI&#xff09;元素的属性与各种数据源关联起来。这种关联可以是单向的、双向的或一次性的。WPF 的数据绑定支持多种数据源&#xff0c;包括普通对…...

华为OD机试2024年真题(基站维修工程师)

基站维修工程师&#xff08;200分&#xff09; 小王是一名基站维护工程师&#xff0c;负责某区域的基站维护。 某地方有n个基站(1<n<10)&#xff0c;已知各基站之间的距离s(0<s<500)&#xff0c;并且基站x到基站y的距离&#xff0c;与基站y到基站x的距离并不一定会…...

在MySQL中为啥引入批量键访问(Batch Key Access, BKA)

批量键访问&#xff08;Batch Key Access, BKA&#xff09; 是 MySQL 在某些情况下用于优化 JOIN 操作的一种技术&#xff0c;特别是在通过索引进行 JOIN 时&#xff0c;它能有效减少查询的随机 I/O。批量键访问优化通过将一批主键或索引键一次性发送给存储引擎来查找匹配的行&…...

912.排序数组(归并排序)

目录 题目解法初始数组1. 分解阶段2. 合并阶段结果 为什么要创建长整型ll mid l ((r - l) >> 1);其中的>>是什么意思 题目 给你一个整数数组 nums&#xff0c;请你将该数组升序排列。 你必须在 不使用任何内置函数 的情况下解决问题&#xff0c;时间复杂度为 O…...

使用 cmake 在 x86 系统中为 arm 系统交叉编译程序

原理&#xff1a; 在 x86 系统里使用交叉编译工具链&#xff08;arm 版 gcc/g&#xff09;编译程序&#xff0c;然后放在 arm 系统里运行。 arm 版本 使用 lscpu 查看 cpu 架构 版本说明armv732 bitarmv8/arrch6464 bit 安装交叉编译工具链 # 针对 armv7 sudo apt install…...

软考(网工)——网络规划设计

文章目录 &#x1f550;综合布线1️⃣结构化布线系统2️⃣综合布线六大子系统3️⃣综合布线物理结构图 &#x1f551;网络分析与设计1️⃣网络规划设计模型2️⃣网络流量分析3️⃣网络安全技术措施表4️⃣技术评价 &#x1f552;网络结构与功能1️⃣局域网结构类型2️⃣三层架构…...

即插即用特征融合模块,即用即涨点!

特征融合&#xff08;Feature Fusion&#xff09;是深度学习中的一种重要技术&#xff0c;它可以帮助模型更好地理解数据的内在结构和规律&#xff0c;提高模型的性能和泛化能力。 另外&#xff0c;特征融合还可以提高模型的分类准确率&#xff0c;减少过拟合风险&#xff0c;…...