在蓝桥杯中定时器的使用是很频繁的,并且定时器的使用也可以让我们的功能实现的更加的完美。

我们这里就主要介绍定时器中断。

我们再来看看硬件上,在stm32f1上主要是用通用定时器来进行中断的。

例如:我们用定时器4进行定时器中断,并且每隔100ms串口打印数据。
tim.h

#include "stm32f10x.h"
#include "usart.h"
void tim4_init(u16 arr,u16 psc);


tim.c

#include "tim.h"
void tim4_Init(u16 arr,u16 psc)
{
	TIM_TimeBaseInitTypeDef  TIM_TimeBaseStructure;
	NVIC_InitTypeDef NVIC_InitStructure;
	
	RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM4, ENABLE);
	
	TIM_TimeBaseStructure.TIM_Period = arr;
    TIM_TimeBaseStructure.TIM_Prescaler = psc;
    TIM_TimeBaseStructure.TIM_ClockDivision = 0;
    TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;

    TIM_TimeBaseInit(TIM4, &TIM_TimeBaseStructure);
	
    NVIC_InitStructure.NVIC_IRQChannel = TIM4_IRQn;
    NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;
    NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0;
    NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;

    NVIC_Init(&NVIC_InitStructure);
	
	TIM_ITConfig(TIM4, TIM_IT_Update, ENABLE);

    TIM_Cmd(TIM4, ENABLE);
}

void TIM4_IRQHandler(void)
{
    if (TIM_GetITStatus(TIM4, TIM_IT_Update) != RESET)
    {
        usart_sendata(USART2," HELLO  ");
        TIM_ClearITPendingBit(TIM4, TIM_IT_Update);
		
	}
}

main

#include "tim.h"
int main()
{
  tim4_init(999,7199);
  while(1)
  {
   ......
  }
}

这样就完成了定时器中断,并且每100ms通过串口发送数据。

Logo

魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。

更多推荐