【STM32】Systick定时器

news2025/1/24 17:34:18

一、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

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.coloradmin.cn/o/1176608.html

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

相关文章

JAVA对象大小的获取

1. Java 对象的内存布局 Java的实例对象、数组对象在内存中的组成包括如下三部分&#xff1a;对象头Hearder、实例数据、内存填充。示意图如下所示 对象头 其主要包括两部分数据&#xff1a;Mark Word、Class对象指针。特别地对于数组对象而言&#xff0c;其还包括了数组长度…

figma-如何批量修改字体

一.选择字体 二.批量替换 编辑—>替换相同字体

3.3、Linux项目自动化构建工具make/makefile

个人主页&#xff1a;Lei宝啊 愿所有美好如期而遇 目录 背景 依赖关系 依赖方法 实例代码 原理 项目清理 背景 会不会写makefile&#xff0c;从一个侧面说明了一个人是否具备完成大型工程的能力再一个&#xff0c;我们平时使用的集成开发环境&#xff0c;创建一个工程…

[量化投资-学习笔记006]Python+TDengine从零开始搭建量化分析平台-MACD

在上一章节介绍了 EMA 均线的计算&#xff0c;本节主要介绍均线的进化形态之一&#xff1a;MACD MACD (Moving Average Convergence / Divergence) 指数平滑移动平均线。MACD 是通过计算不同时间的 EMA 的差值俩判断价格趋势。 MACD 包括 3 个值&#xff1a; 长短期 EMA 差值…

信号上的串联电阻是如何改善信号质量的

一般我们在进行PCB设计时可能会留意到有些信号会串联一个电阻&#xff0c;那么大家是否有想过所串联的电阻是有什么作用呢&#xff1f; 大家可以看一下下面图示的案例&#xff0c;信号是从CPU处出来再接到DDR颗粒的&#xff0c;每一个DDR数据线都有串联一个电阻&#xff0c;其…

高速串行协议——Aurora

Aurora简介 Aurora 协议是一个用于在点对点串行链路间移动数据的轻量级链路层协议&#xff0c;并为物理层提供透明接口&#xff0c;让专有协议或业界标准协议上层能方便地使用高速收发器。 Aurora通信模型 在发送端&#xff0c;用户端应用程序可以通过AXI总线接口实现与Aurora…

虹科示波器 | 汽车免拆检测 | 2017款长安福特翼虎车发动机故障灯异常点亮

一、故障现象 一辆2017款长安福特翼虎车&#xff0c;搭载CAF488WQ9发动机&#xff0c;累计行驶里程约为8.9万km。该车因发动机故障灯异常点亮在其他维修厂检修&#xff0c;维修人员用故障检测仪检测&#xff0c;提示气缸3失火&#xff0c;调换火花塞、点火线圈及喷油器&#xf…

Sandcastle生成文档

下载: https://github.com/EWSoftware/SHFB/releases 使用Sandcastle生成Api文档需要使用对应程序集的注释xml 程序集dll作为数据源&#xff0c;通过对xml dll数据解析生成文档&#xff1b;所以主体步骤如下&#xff1a; 程序集资源生成创建配置.shfbproj项目编译构建文档 …

累计概率分布、概率分布函数(概率质量函数、概率密度函数)、度量空间、负采样(Negative Sampling)

这里写自定义目录标题 机器学习的基础知识累计概率分布概率分布函数度量空间负采样&#xff08;Negative Sampling&#xff09;基于分布的负采样&#xff08;Distribution-based Negative Sampling&#xff09;&#xff1a;基于近邻的负采样&#xff08;Neighbor-based Negativ…

【Linux进程】进程地址空间

目录 程序地址空间回顾 进程地址空间 宏观理解 谈细节 1、进程地址空间究竟是什么&#xff1f; 2、管理地址空间 3、页表 总结几个问题&#xff1a; 1、为什么要有进程地址空间&#xff1f; 2、进程切换 3、进程具有独立性&#xff0c;怎么做到的&#xff1f; 程序地…

C++程序崩溃时,使用Windbg静态分析dump文件

Window环境下的C程序如果发生异常崩溃&#xff0c;首先会和客户联系&#xff0c;让帮忙取特定目录下的dump文件和log文件来分析崩溃的原因。不过发生崩溃的话&#xff0c;从log一般分析不出特定原因&#xff0c;这时候dump文件就起作用了。可以通过Visual Studio和WinDbg来静态…

看看顶级外贸业务员是如何跟进客户的?

许多外贸业务员&#xff0c;都碰到过客户跟进上的困难。那到底外贸业务员如何跟进客户&#xff0c;才能越跟越近&#xff0c;最终成交呢&#xff1f;本篇文章设定了几个客户回复的场景&#xff0c;看看顶尖销售都是怎么应对的吧&#xff1f; 一 客户说暂时没有需求 1.问清楚客…

京东app地推拉新和京喜大赢家网推app拉新申请渠道 附全套攻略

京东app地推拉新和京喜大赢家网推拉新可以通过“聚量推客”申请 聚量推客是什么呢&#xff1f;一手官签服务商直营app拉新平台 京东app地推拉新项目和京喜大赢家网推拉新项目有什么区别呢&#xff1f; 京东app只能地推作业&#xff0c;京喜大赢家推广支持网推推广操作也更简…

【C语法学习】18 - fread()函数

文章目录 1 函数原型2 参数3 返回值4 示例 1 函数原型 fread()&#xff1a;从与指定流stream相关联的二进制文件中读取数据块储存在str指向的内存空间中&#xff0c;函数原型如下&#xff1a; size_t fread(const void *ptr, size_t size, size_t count, FILE *stream)2 参数…

为什么大家都想找运营类的工作?

为什么大家都想找运营类的工作&#xff1f; 一、入门门槛 随着需求的持续增长&#xff0c;市场上的人员素质难以迅速匹配。在高校中&#xff0c;也难以培养出对口的应届毕业生。因此&#xff0c;许多企业在招聘运营人员时&#xff0c;更倾向于自行培养。对于新人的要求相对较低…

酒水展示预约小程序的效果如何

酒的需求度非常高&#xff0c;各种品牌、海量经销商组成了庞大市场&#xff0c;而在实际经营中&#xff0c;酒水品牌、经销商、门店经营者等环节往往也面临着品牌传播拓客引流难、产品展示预约订购难、营销难、销售渠道单一等痛点。 那么商家们应该怎样解决呢&#xff1f; 可以…

MTK RILD 无法启动问题分析

1、问题背景 Modem识别卡&#xff0c;但是UI无法识别卡&#xff0c;抓取问题机开机Log&#xff0c;发现RILJ一直在找寻RILD&#xff0c;但是无法获取相关服务&#xff0c;因此可以确认RILD Crash或出现异常。 但是在异常Log中搜索RILD&#xff0c;也未见相关关键字Log 2、对比实…

Springboot+vue的导师双选管理系统(有报告)。Javaee项目,springboot vue前后端分离项目。

演示视频&#xff1a; Springbootvue的导师双选管理系统&#xff08;有报告&#xff09;。Javaee项目&#xff0c;springboot vue前后端分离项目。 项目介绍&#xff1a; 本文设计了一个基于Springbootvue的前后端分离的导师双选管理系统&#xff0c;采用M&#xff08;model&a…

享搭低代码平台:加速费用报销管理系统应用构建的利器

低代码平台的概念与优势 低代码平台是一种应用开发工具&#xff0c;它通过图形化界面和少量编码&#xff0c;使开发人员能够快速构建应用程序。它的优势包括提高开发效率、降低技术门槛、加强协作和灵活性等。 享搭低代码平台实现快速构建费用报销管理系统应用 在享搭低代码…

Web3.0的测试题

任务&#xff1a; 在前端开发一个查询UI&#xff0c;查询当前用户账户的ETH余额和指定ERC20合约中的余额 目标&#xff1a; UI框架指定使用 MUI (https://mui.com)需要查询到当前账户的ETH余额并展示在UI界面上需要输入ERC20合约地址后&#xff0c;查询到到当前账户在此ERC20…