【STM32】Systick定时器

一、STM32的5种定时器简介

1.独立看门狗(IWDG) VS 窗口看门狗(WWDG)

1.独立看门狗(IWDG)

独立看门狗:当没有到设定时间之前,给它喂了狗,就会回到初始值。

2.窗口看门狗(WWDG)

窗口看门狗:只有在设定的窗口时间范围内喂才可以起效果

最适合哪些要求看门狗在精确计时窗口起作用。

2.Systick定时器

3.高级定时器(TIM1+TIM8)

4.通用定时器(TIMx)

1)输入捕获:通过输入电平进行捕获

2)产生中断:

        定时器时间到

        触发事件

3)正交编码器和霍尔传感器(测小车速度)

5.基本定时器(TIM6 & TIM7)

1)最多只能计数65535(2的16次方)

2)预分频器(因为在定时器的频率不需要那么快)

3)可以产生中断

二、SYSTICK定时器

0.SYSTICK的提出

我们之前的51只有一个主线(无操作系统),一个进程走到死

我们想要多种进程并行工作,但是实际上无法这样。因为后面的程序可能还没有等到执行,时间就结束了。所以我们将每一个程序都分成多个小进程,第一个进程的第一个小部分执行完成在执行第二个进程的第一小部分....【从而实现微观上的串行,宏观上的并行】

1.SYSTICK定时器的作用

1)专用于生产RTOS的系统滴答时钟【因为RTOS需要多进程执行】

2)可用于裸机程序中短时间精确延时函数

3)可用于普通定时器中断功能

2.SYSTICK定时器的数据手册

https://www.st.com/resource/en/programming_manual/cd00228163-stm32f10xxx-20xxx-21xxx-l1xxxx-cortex-m3-programming-manual-stmicroelectronics.pdf

SYSTICK和NVIC不属于SoC部分【属于内核外设】

1.24个定时器

2.各种寄存器

1.STK_CTRL(控制状态)

2.STK_LOAD(初始值)

我们计算出来的值要-1

因为计时是4 3 2 1 0 4 3 2 1 0【0才表示结束】

3.STK_VAL(计数值)

4.STK_CALIB

校准

3.SYSTICK寄存器在标准库中的封装

SYSTICK放在misc.c中

1. SysTick_CLKSourceConfig--分频设置

本函数在misc.c中

SYSTICK本身没有分频器。所以需要通过本函数进行设置

/**
  * @brief  Configures the SysTick clock source.
  * @param  SysTick_CLKSource: specifies the SysTick clock source.
  *   This parameter can be one of the following values:
  *     @arg SysTick_CLKSource_HCLK_Div8: AHB clock divided by 8 selected as SysTick clock source.
  *     @arg SysTick_CLKSource_HCLK: AHB clock selected as SysTick clock source.
  * @retval None
  */
void SysTick_CLKSourceConfig(uint32_t SysTick_CLKSource)
{
  /* Check the parameters */
  assert_param(IS_SYSTICK_CLK_SOURCE(SysTick_CLKSource));
  if (SysTick_CLKSource == SysTick_CLKSource_HCLK)
  {
    SysTick->CTRL |= SysTick_CLKSource_HCLK;
  }
  else
  {
    SysTick->CTRL &= SysTick_CLKSource_HCLK_Div8;
  }
}

全局搜索SYSTICK

2.SysTick_Config--触发systick中断

本函数在core_cm3.h中

Systick config函数配置的状况是: 默认使用AHB时钟。会产生中断,中断优先级为最低,并且最末尾启动了定时器

/**
 * @brief  Initialize and start the SysTick counter and its interrupt.
 *
 * @param   ticks   number of ticks between two interrupts
 * @return  1 = failed, 0 = successful
 *
 * Initialise the system tick timer and its interrupt and start the
 * system tick timer / counter in free running mode to generate 
 * periodical interrupts.
 */
 /**
	Systick config函数配置的状况是:
		默认使用AHB时钟。会产生中断
		中断优先级为最低,并且最末尾启动了定时器
*/
static __INLINE uint32_t SysTick_Config(uint32_t ticks)
{ 
//检验有没有超过24位寄存器
//SysTick_LOAD_RELOAD_Msk:  0xFFFFFFul
  if (ticks > SysTick_LOAD_RELOAD_Msk)  return (1);            /* Reload value impossible */
//减一:因为我们是从0开始的 ,但是一般我们都不在乎因为影响不大                                                              
  SysTick->LOAD  = (ticks & SysTick_LOAD_RELOAD_Msk) - 1;      /* set reload register */
//设置中断优先级,默认设置最低
  NVIC_SetPriority (SysTick_IRQn, (1<<__NVIC_PRIO_BITS) - 1);  /* set Priority for Cortex-M0 System Interrupts */
  SysTick->VAL   = 0;      //让它上来直接完了                                    /* Load the SysTick Counter Value */
  //SysTick_CTRL_CLKSOURCE_Msk(1):默认使用AHB
  //SysTick_CTRL_TICKINT_Msk:默认会产生中断
  //SysTick_CTRL_ENABLE_Msk:启动了定时器
  SysTick->CTRL  = SysTick_CTRL_CLKSOURCE_Msk | 
                   SysTick_CTRL_TICKINT_Msk   | 
                   SysTick_CTRL_ENABLE_Msk;                    /* Enable SysTick IRQ and SysTick Timer */
  return (0);                                                  /* Function successful */

3.注意点:SysTick_Config VS SysTick_CLKSourceConfig的调用顺序

我们在调用库函数进行初始化的时候,要先调用【SysTick_Config】然后再调用【SysTick_CLKSourceConfig】,因为再【SysTick_Config】中对Systick_CTRL中是对其中几位bit进行直接赋值,而不是位或。所以如果先定义【SysTick_CLKSourceConfig】则相关寄存器的值可能被覆盖掉。

4.SYSTICK定时器的2种工作方式

1.中断方式

使能后,到中断处理程序查

2.查询方式

检测STK_VAL,因为VAL会不断减少

5.SYSTICK定时器的定时计算

1.公式:重装载值=systick时钟频率(Hz)*想要定的时间(s)

2.例子:1ms 

我们使用原始的频率:72MHZ=72 000 000HZ

以1s为单位---》1ms==0.001s

CNT=72 000 000*0.001=72 000

查看是否超过2的24次方

3.查询方式和中断方式都这样计算

6.SYSTICK中断实现LED每200ms闪烁一次【中断方式-interrupt】

https://www.cnblogs.com/kinson/p/7967332.html

0.注意点:

1)SYSTICK是自动清除中断,不需要手动将其清除

2)SYSTICK是内核中的,所以不需要打开SYSTICK时钟,它一直都是打开的

1.接线

我们将led的j19接到PB0-PB7,但是实际上我们就操作led1,所以使用到PB0

2.NVIC_Configuration

因为我们的Systick中断不属于外设中断,所以不需要设置NVIC的部分设置。

void NVIC_Configuration(void)
{
 // NVIC_InitTypeDef NVIC_InitStructure;
  
#ifdef  VECT_TAB_RAM  
  /* Set the Vector Table base location at 0x20000000 */ 
  NVIC_SetVectorTable(NVIC_VectTab_RAM, 0x0);   //分配中断向量表
#else  /* VECT_TAB_FLASH  */
	//表示从FLASH中启动;;
  /* Set the Vector Table base location at 0x08000000 */ 
  NVIC_SetVectorTable(NVIC_VectTab_FLASH, 0x0);   
#endif

  /* Configure one bit for preemption priority */
  // NVIC_PriorityGroup_1:2个抢占优先级,8个次优先级
	
	/*
  NVIC_PriorityGroupConfig(NVIC_PriorityGroup_1);  //设置中断优先级
  
  // Enable the SYSTICK Interrupt 
	//设置为SYSTICK
	//这里我们将下面代码注释起来是因为【NVIC_IRQChannel】只接受正整数
	//但是我们【SysTick_IRQn】是负数,所以不能正确输出
  NVIC_InitStructure.NVIC_IRQChannel = SysTick_IRQn; //中断通道
  NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority =  0;  //强占优先级
  NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0;//次优先级
  NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;  //通道中断使能
  NVIC_Init(&NVIC_InitStructure);//初始化中断
	*/
}

3.GPIO_Configuration

//GPIO初始化
void GPIO_Configuration(void){
	
	GPIO_InitTypeDef GPIO_InitStructure;

	
	//PB0 ---LED1【LED的显示输出】
	GPIO_InitStructure.GPIO_Pin = GPIO_Pin_8;
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;       //推挽输出
  GPIO_Init(GPIOB, &GPIO_InitStructure);
	// 默认输出0让LED亮
	//RESET=0
	//SET=1
  GPIO_WriteBit(GPIOB, GPIO_Pin_8, Bit_RESET);			

}

4.RCC_Configuration

//RCC的配置
void RCC_Configuration(void){
	
	//因为起始代码中已经调用SystemInit将主时钟设置为72MHZ
	//所以我们这里RCC直接使能时钟就可以
	
	//使能GPIO端口
	//通过PB0控制LED1
	//因为我们使用到的是PB0,所以只使用到GPIOB
	RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB,ENABLE);
	//因为systick属于cpu部分的,所以时钟始终打开的,不需要再去打开
	//所以这里只是打开GPIO的时钟即可
	
}

5. SYSTICK_Configuration

//SysTick_Config:是SYSTICK的启动函数
void SYSTICK_Configuration(void){
	/*
	这个时间超时了
	//主频是72MHZ,定时时间是500ms
	//ticks=72 000 000*0.5 =3600 000
	SysTick_Config(36000000);//1677 7216
	*/
	//100毫秒
	//范围:233ms
	//ticks=72 000 000*200ms=14400000
	SysTick_Config(14400000);
	//SysTick_CLKSourceConfig(SysTick_CLKSource_HCLK_Div8);
}

6.main

#include "stm32f10x.h"                  // Device header
/**
	使用SYSTICK控制led的闪烁【中断式】
	PB8控制LED8
*/

//函数声明
//RCC的配置
void RCC_Configuration(void);
//GPIO初始化
void GPIO_Configuration(void);
void NVIC_Configuration(void);
void SYSTICK_Configuration(void);

//全局变量定义
EXTI_InitTypeDef EXTI_InitStructure;
ErrorStatus HSEStatartUpStatus;


int main(){
	//系统时钟配置
	RCC_Configuration();
	//NVIC配置
	NVIC_Configuration();
	//配置GPIO
	GPIO_Configuration();
	
	SYSTICK_Configuration();
	
	while(1);
	return 0;
}

//RCC的配置
void RCC_Configuration(void){
	
	//因为起始代码中已经调用SystemInit将主时钟设置为72MHZ
	//所以我们这里RCC直接使能时钟就可以
	
	//使能GPIO端口
	//通过PB0控制LED1
	//因为我们使用到的是PB0,所以只使用到GPIOB
	RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB,ENABLE);
	//因为systick属于cpu部分的,所以时钟始终打开的,不需要再去打开
	//所以这里只是打开GPIO的时钟即可
	
}


//GPIO初始化
void GPIO_Configuration(void){
	
	GPIO_InitTypeDef GPIO_InitStructure;

	
	//PB0 ---LED1【LED的显示输出】
	GPIO_InitStructure.GPIO_Pin = GPIO_Pin_8;
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;       //推挽输出
  GPIO_Init(GPIOB, &GPIO_InitStructure);
	// 默认输出0让LED亮
	//RESET=0
	//SET=1
  GPIO_WriteBit(GPIOB, GPIO_Pin_8, Bit_RESET);			

}

void NVIC_Configuration(void)
{
 // NVIC_InitTypeDef NVIC_InitStructure;
  
#ifdef  VECT_TAB_RAM  
  /* Set the Vector Table base location at 0x20000000 */ 
  NVIC_SetVectorTable(NVIC_VectTab_RAM, 0x0);   //分配中断向量表
#else  /* VECT_TAB_FLASH  */
	//表示从FLASH中启动;;
  /* Set the Vector Table base location at 0x08000000 */ 
  NVIC_SetVectorTable(NVIC_VectTab_FLASH, 0x0);   
#endif

  /* Configure one bit for preemption priority */
  // NVIC_PriorityGroup_1:2个抢占优先级,8个次优先级
	
	/*
  NVIC_PriorityGroupConfig(NVIC_PriorityGroup_1);  //设置中断优先级
  
  // Enable the SYSTICK Interrupt 
	//设置为SYSTICK
	//这里我们将下面代码注释起来是因为【NVIC_IRQChannel】只接受正整数
	//但是我们【SysTick_IRQn】是负数,所以不能正确输出
  NVIC_InitStructure.NVIC_IRQChannel = SysTick_IRQn; //中断通道
  NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority =  0;  //强占优先级
  NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0;//次优先级
  NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;  //通道中断使能
  NVIC_Init(&NVIC_InitStructure);//初始化中断
	*/
}

//SysTick_Config:是SYSTICK的启动函数
void SYSTICK_Configuration(void){
	/*
	这个时间超时了
	//主频是72MHZ,定时时间是500ms
	//ticks=72 000 000*0.5 =3600 000
	SysTick_Config(36000000);//1677 7216
	*/
	//100毫秒
	//范围:233ms
	//ticks=72 000 000*200ms=14400000
	SysTick_Config(14400000);
	//SysTick_CLKSourceConfig(SysTick_CLKSource_HCLK_Div8);
}


7.注意点:ticks的时间设置

我们已经知道systick有24个寄存器,所以我们最大的数值范围不能超过2的24次方。

所以我们计算出来的值不能超过上面那个

而根据我们单片机上面使用的是72MHZ的频率

则我们ticks的范围是16 777 216/72 000 000

举个例子

如果我们想要设置100ms

则ticks=72 000 000 *0.1=7,200,000

8.SYSTICK中断实现LED每200ms闪烁一次【查询方式--delay】

0.解释

我们通过使用delay进行精确的延时

1.代码解析

 1.GPIO_Configuration

//GPIO初始化
void GPIO_Configuration(void){
	
	GPIO_InitTypeDef GPIO_InitStructure;

	
	//PB0 ---LED1【LED的显示输出】
	GPIO_InitStructure.GPIO_Pin = GPIO_Pin_8;
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;       //推挽输出
  GPIO_Init(GPIOB, &GPIO_InitStructure);
	// 默认输出0让LED亮
	//RESET=0
	//SET=1
  GPIO_WriteBit(GPIOB, GPIO_Pin_8, Bit_RESET);			

}

2.RCC_Configuration

//RCC的配置
void RCC_Configuration(void){
	
	//因为起始代码中已经调用SystemInit将主时钟设置为72MHZ
	//所以我们这里RCC直接使能时钟就可以
	
	//使能GPIO端口
	//通过PB0控制LED1
	//因为我们使用到的是PB0,所以只使用到GPIOB
	RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB,ENABLE);
	//因为systick属于cpu部分的,所以时钟始终打开的,不需要再去打开
	//所以这里只是打开GPIO的时钟即可
	
}

3.delay_us

此代码要根据频率来进行修改

//用systick计数器来帮我们实现us级别的精确延时
//这个函数成立有2个条件:
//1.主频必须是72MHZ
//2.us要小于(2的24次方)=1864 135us=1.8s
void delay_us(unsigned int us){
	
	//记录CTRL的countflag位的值
	unsigned int tmp=0;
	
	//思路是先把systick的时钟源设置好,然后给一个正确的ticks
	//然后使能systick,while循环等待countflag置位则时间到
	
	//72MHZ主频,我们使用8分频,72/8=9MHZ systick
	 SysTick->LOAD=us*9;
	 SysTick->VAL=0;
	//我们要先设置上面的LOAD和VAL,在进行使能
	//时钟源是AHB/8,禁止中断,使能systick
	 SysTick->CTRL =0x01;
	
	//检测什么时候时间结束
	//查看CTRL中的countflag
	do{
		tmp=SysTick->CTRL;
	}while(!(tmp&(1<<16)));
	
	//时间到,关闭定时器
	SysTick->VAL=0;
	SysTick->CTRL =0x00;
}

4.delay_ms

//不能大于 1864
void delay_ms(unsigned int ms){
	
	//记录CTRL的countflag位的值
	unsigned int tmp=0;
	
	//思路是先把systick的时钟源设置好,然后给一个正确的ticks
	//然后使能systick,while循环等待countflag置位则时间到
	
	//72MHZ主频,我们使用8分频,72/8=9MHZ systick
	 SysTick->LOAD=ms*9000;
	 SysTick->VAL=0;
	//我们要先设置上面的LOAD和VAL,在进行使能
	//时钟源是AHB/8,禁止中断,使能systick
	 SysTick->CTRL =0x01;
	
	//检测什么时候时间结束
	//查看CTRL中的countflag
	do{
		tmp=SysTick->CTRL;
	}while(!(tmp&(1<<16)));
	
	//时间到,关闭定时器
	SysTick->VAL=0;
	SysTick->CTRL =0x00;
	
}

5.main

#include "stm32f10x.h"                  // Device header
/**
	使用delay控制led的闪烁--与systick进行等价实现【查询式】
	PB8控制LED8
*/

//函数声明
//RCC的配置
void RCC_Configuration(void);
//GPIO初始化
void GPIO_Configuration(void);

void delay_ms(unsigned int ms);
void delay_us(unsigned int us);

//全局变量定义
EXTI_InitTypeDef EXTI_InitStructure;
ErrorStatus HSEStatartUpStatus;


int main(){
	//系统时钟配置
	RCC_Configuration();
	
	//配置GPIO
	GPIO_Configuration();
	
	
	while(1){
		GPIO_WriteBit(GPIOB,GPIO_Pin_8,Bit_RESET);//亮
		delay_ms(200);
		GPIO_WriteBit(GPIOB,GPIO_Pin_8,Bit_SET);//灭
		delay_ms(200);
	}
	return 0;
}

//RCC的配置
void RCC_Configuration(void){
	
	//因为起始代码中已经调用SystemInit将主时钟设置为72MHZ
	//所以我们这里RCC直接使能时钟就可以
	
	//使能GPIO端口
	//通过PB0控制LED1
	//因为我们使用到的是PB0,所以只使用到GPIOB
	RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB,ENABLE);
	//因为systick属于cpu部分的,所以时钟始终打开的,不需要再去打开
	//所以这里只是打开GPIO的时钟即可
	
}


//GPIO初始化
void GPIO_Configuration(void){
	
	GPIO_InitTypeDef GPIO_InitStructure;

	
	//PB0 ---LED1【LED的显示输出】
	GPIO_InitStructure.GPIO_Pin = GPIO_Pin_8;
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;       //推挽输出
  GPIO_Init(GPIOB, &GPIO_InitStructure);
	// 默认输出0让LED亮
	//RESET=0
	//SET=1
  GPIO_WriteBit(GPIOB, GPIO_Pin_8, Bit_RESET);			

}

//用systick计数器来帮我们实现us级别的精确延时
//这个函数成立有2个条件:
//1.主频必须是72MHZ
//2.us要小于(2的24次方)=1864 135us=1.8s
void delay_us(unsigned int us){
	
	//记录CTRL的countflag位的值
	unsigned int tmp=0;
	
	//思路是先把systick的时钟源设置好,然后给一个正确的ticks
	//然后使能systick,while循环等待countflag置位则时间到
	
	//72MHZ主频,我们使用8分频,72/8=9MHZ systick
	 SysTick->LOAD=us*9;
	 SysTick->VAL=0;
	//我们要先设置上面的LOAD和VAL,在进行使能
	//时钟源是AHB/8,禁止中断,使能systick
	 SysTick->CTRL =0x01;
	
	//检测什么时候时间结束
	//查看CTRL中的countflag
	do{
		tmp=SysTick->CTRL;
	}while(!(tmp&(1<<16)));
	
	//时间到,关闭定时器
	SysTick->VAL=0;
	SysTick->CTRL =0x00;
}


//不能大于 1864
void delay_ms(unsigned int ms){
	
	//记录CTRL的countflag位的值
	unsigned int tmp=0;
	
	//思路是先把systick的时钟源设置好,然后给一个正确的ticks
	//然后使能systick,while循环等待countflag置位则时间到
	
	//72MHZ主频,我们使用8分频,72/8=9MHZ systick
	 SysTick->LOAD=ms*9000;
	 SysTick->VAL=0;
	//我们要先设置上面的LOAD和VAL,在进行使能
	//时钟源是AHB/8,禁止中断,使能systick
	 SysTick->CTRL =0x01;
	
	//检测什么时候时间结束
	//查看CTRL中的countflag
	do{
		tmp=SysTick->CTRL;
	}while(!(tmp&(1<<16)));
	
	//时间到,关闭定时器
	SysTick->VAL=0;
	SysTick->CTRL =0x00;
	
}







2.中断 VS 查询

查询和中断方式差异:

查询方式是阻塞式的,中断方式是非阻塞的

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【Linux】:初识git || centos下安装git || 创建本地仓库 || 配置本地仓库 || 认识工作区/暂存区(索引)以及版本库

&#x1f4ee;1.初识git Git 原理与使用 课程⽬标 • 技术⽬标:掌握Git企业级应⽤&#xff0c;深刻理解Git操作过程与操作原理&#xff0c;理解⼯作区&#xff0c;暂存区&#xff0c;版本库的含义 • 技术⽬标:掌握Git版本管理&#xff0c;⾃由进⾏版本回退、撤销、修改等Git操…

.NET Framework中自带的泛型委托Func

Func<>是.NET Framework中自带的泛型委托&#xff0c;可以接收一个或多个输入参数&#xff0c;并且有返回值&#xff0c;和Action类似&#xff0c;.NET基类库也提供了多达16个输入参数的Func委托&#xff0c;输出参数只有1个。 1、Func泛型委托 .NET Framework为我们提…

声音训练数据集哪里找?中文、英文

一般找数据集的都是需要训练底膜的&#xff0c;大家git上找的开源项目大多是预训练模型。预训练就是别人已经训练好的底膜&#xff0c;你在他的基础上进行调整。而我们训练如果他这个模型不理想是需要训练底膜的。 找的方式是从git开源上找 中文 推荐MockingBird&#xff0c;…

单链表的实现

单链表的实现 单链表的链表的概念及结构概念结构链表结构的分类链表常用的结构 无头单向不循环链表头文件 SList.h结构体 struct SListNode 源文件 SList.c创建结点 SLNode* SLBuyNode(SLDataType x)初始化链表 void SLInit(SLNode** pphead)链表尾部插入 void SLPushBack(SLNo…

【Qt之绘制兔纸】

效果 代码 class drawRabbit: public QWidget { public:drawRabbit(QWidget *parent nullptr) : QWidget(parent) {}private:void paintEvent(QPaintEvent *event) {QPainter painter(this);painter.setRenderHint(QPainter::Antialiasing, true);// 绘制兔子的耳朵painter.s…

案例研究|腾讯音乐娱乐集团与JumpServer共探安全运维审计解决方案

近年来&#xff0c;得益于人民消费水平的提升以及版权意识的加强&#xff0c;用户付费意愿和在线用户数量持续增长&#xff0c;中国在线音乐市场呈现出稳定增长的发展态势。随着腾讯音乐于2018年12月上市&#xff0c;进一步推动了中国在线音乐市场的发展。 腾讯音乐娱乐集团&a…

用Rust和Scraper库编写图像爬虫的建议

本文提供一些有关如何使用Rust和Scraper库编写图像爬虫的一般建议&#xff1a; 1、首先&#xff0c;你需要安装Rust和Scraper库。你可以通过Rustup或Cargo来安装Rust&#xff0c;然后使用Cargo来安装Scraper库。 2、然后&#xff0c;你可以使用Scraper库的Crawler类来创建一个…

Config

因为我们微服务的模块太多了&#xff0c;这样每一个都有一个application.yml文件&#xff0c;假如说此时数据库的配置变了&#xff0c;这样一个个修改yml文件太麻烦了&#xff0c;所以我们想要一套集中式的&#xff0c;动态的配置管理设施是必不可少的。此时SpringCloud Config…

爬取Elastic Stack采集的Nginx内容

以下是一个简单的Go语言爬虫程序&#xff0c;用于爬取Elastic Stack采集的Nginx内容。请注意&#xff0c;这只是一个基本的示例&#xff0c;实际使用时可能需要根据具体情况进行修改和扩展。 package mainimport ("fmt""net/http""io/ioutil" )…

Intel oneAPI笔记(4)--jupyter官方文档(Unified Shared Memory)学习笔记

前言 本文是对jupyterlab中oneAPI_Essentials/03_Unified_Shared_Memory文档的学习记录&#xff0c;主要包含对统一共享内存的讲解 USM概述 USM (Unified Shared Memory)是SYCL中基于指针的内存管理。对于使用malloc或new来分配数据的C和C程序员来说应该很熟悉。当将现有的C…

【H616_语言小美_控制安卓刷抖音项目 orangePi zero2 (已开源) 】.md uptada:23/11/07

文章目录 H616_语言小美_控制安卓刷抖音项目小美效果展示H616 ubuntu系统 安装adb智能公元 SU-03T 离线语音模组 固件制作配合串口实现 小美_控制安卓刷抖音 H616_语言小美_控制安卓刷抖音项目 注意&#xff1a;orangePi zero2 H616 安装系统为ubuntu 小美效果展示 语言小美 …

基于springboot实现招生平台管理系统项目【项目源码+论文说明】计算机毕业设计

基于springboot实现招生管理系统演示 摘要 在Internet高速发展的今天&#xff0c;我们生活的各个领域都涉及到计算机的应用&#xff0c;其中包括招生管理系统的网络应用&#xff0c;在外国招生管理系统已经是很普遍的方式&#xff0c;不过国内的管理网站可能还处于起步阶段。招…

笔记50:正则表达式入门宝典

引自&#xff1a;正则表达式是什么? - 知乎 中“龙吟九野”所写的一个回答&#xff0c;个人感觉看完之后如同醍醐灌顶&#xff0c;查了很多资料都没有这篇文章写的基础和通透&#xff0c;感觉是正则表达式扫盲好文&#xff0c;所以搬运一下&#xff0c;侵权删&#xff0c;感谢…

如何使用 Loadgen 来简化 HTTP API 请求的集成测试

引言 在编写 HTTP 服务的过程中&#xff0c;集成测试 1 是保证程序正确性的重要一环&#xff0c;如下图所示&#xff0c;其基本的流程就是不断向服务发起请求然后校验响应的状态和数据等&#xff1a; 为大量的 API 和用例编写测试是一件繁琐的工作&#xff0c;而 Loadgen 2 正…

高效接口重试机制的实现

实现一个高效的接口重试机制对于保证系统的稳定性和可靠性至关重要。在面对网络不稳定、服务端故障或者高负载的情况下&#xff0c;接口重试机制能够确保请求的成功执行&#xff0c;同时也需要保证在重试过程中不会造成额外的负担或不必要的延迟。本文将为您介绍高效接口重试机…

IO多路复用 Linux C Server-Client 多用户聊天系统

目录 Server-Client mutiplexingServer mutiplexingClient mutiplexing Server-Client 在Linux系统中&#xff0c;IO多路复用是一种机制&#xff0c;它允许一个进程能够监视多个文件描述符&#xff08;sockets、pipes等&#xff09;的可读、可写和异常等事件。这样&#xf…

武器检测YOLOV8NANO

武器检测&#xff08;匕首&#xff0c;步枪&#xff0c;手枪&#xff09;&#xff0c;采用YOLOV8NANO训练&#xff0c;得到pt模型&#xff0c;然后转换成Onnx模型&#xff0c;供OPENCV DNN调用&#xff0c;支持C,PYTHON,ANDROID。有标注的训练集 武器检测YOLOV8NANO

macOS磁盘分区调整软件--Paragon Camptune X 中文

Paragon Camptune X是一款专为Mac用户设计的强大分区大小调整工具。通过它&#xff0c;用户可以简便地调整Mac硬盘上的分区大小&#xff0c;实现存储空间的高效管理。无论是需要在Mac和Windows系统之间切换的双系统用户&#xff0c;还是有其他特定存储需求的用户&#xff0c;Ca…

提高 bbr 的灵敏性

bbr draft 给出了 MaxBwFilterLen 的定义&#xff1a; MaxBwFilterLen: The filter window length for BBR.MaxBwFilter 2 (representing up to 2 ProbeBW cycles, the current cycle and the previous full cycle). 从 v1 到 v3 版本&#xff0c;该值均只跟状态机而不跟实际&…

波形的哪些事

一.静音波形制造(波形卡顿制造) 二.pop波形制造 三.示波器探头设置 四.示波器的差分输入和单端输入的接法不一样 差分的接法&#xff0c;需要配差分探头(如下图)&#xff0c;差分探头的两个脚分别和功放输出通道的两个脚连接 单端的接法&#xff0c;需要单端的探头&#xff0c…
最新文章