单片机延时函数实现

单片机延时函数实现在编写单片机程序时 我们经常要用到延时函数 记得我们在学 51 单片机时 第一个延时是通过软件延时来实现的 代码如下 voiddelay volatileuint tcnt volatileuint ti 0 volatileuint tj 0 for i 0 i

在编写单片机程序时,我们经常要用到延时函数,记得我们在学51单片机时,第一个延时是通过软件延时来实现的,代码如下:

void delay(volatile uint32_t cnt) { 
    volatile uint32_t i = 0; volatile uint32_t j = 0; for(i = 0;i<cnt;i++) for(j = 0;j<1000;j++); } 

软件延时的优点是方便,然而却不能提供很精确的延时,而且占用CPU资源,下面的以STM32L1为例,采用定时器方式实现,可以提供很精确的延时。代码如下:

/* CPU主频:32MHz Timer2_clk = 32MHz */ void Delay_Init(void) { 
    /* TIM2 clock enable */ RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM2, ENABLE); } void Delay_ms(uint16_t ms) { 
    TIM_TimeBaseInitTypeDef TIM_TimeBaseStructure; TIM_TimeBaseStructure.TIM_Period = ms - 1; TIM_TimeBaseStructure.TIM_Prescaler = 32000 - 1; TIM_TimeBaseStructure.TIM_ClockDivision = TIM_CKD_DIV1; TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up; /*每当初始化计数器会使计数器更新,TIM_FLAG_Update被置位*/ TIM_TimeBaseInit(TIM2, &TIM_TimeBaseStructure); TIM_ClearFlag(TIM2, TIM_FLAG_Update); TIM_Cmd(TIM2, ENABLE); while (TIM_GetFlagStatus(TIM2, TIM_FLAG_Update) == RESET); TIM_Cmd(TIM2, DISABLE); } void Delay_us(uint16_t us) { 
    TIM_TimeBaseInitTypeDef TIM_TimeBaseStructure; /* Time base configuration */ TIM_TimeBaseStructure.TIM_Period = us - 1; TIM_TimeBaseStructure.TIM_Prescaler = 32 - 1; TIM_TimeBaseStructure.TIM_ClockDivision = TIM_CKD_DIV1; TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up; TIM_TimeBaseInit(TIM2, &TIM_TimeBaseStructure); TIM_ClearFlag(TIM2, TIM_FLAG_Update); TIM_Cmd(TIM2, ENABLE); while (TIM_GetFlagStatus(TIM2, TIM_FLAG_Update) == RESET); TIM_Cmd(TIM2, DISABLE); } 

调用延时函数时,我们每次对定时器的溢出时间进行设置,我们以更新标志置位作为延时结束。注意上面函数的参数不能为1,如果为1会使函数跑死。当然这个延时函数也是阻塞式的。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/176842.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月26日 下午8:54
下一篇 2026年3月26日 下午8:55


相关推荐

  • ExecutorService 的理解与使用「建议收藏」

    ExecutorService 的理解与使用「建议收藏」接口java.util.concurrent.ExecutorService表述了异步执行的机制,并且可以让任务在后台执行。壹個ExecutorService实例因此特别像壹個线程池。事实上,在java.util.concurrent包中的ExecutorService的实现就是壹個线程池的实现。ExecutorService样例这里有壹個简单的使用Java实现的

    2025年10月22日
    5
  • Android空格符

    Android空格符以下是效果图 nbsp 把中间内容放大 方便对比 以下是中间放大的效果图 nbsp 转自 https blog csdn net wlz287 article details nbsp

    2026年3月19日
    2
  • 程序员外包平台_人力资源外包和劳务派遣

    程序员外包平台_人力资源外包和劳务派遣程序员接单平台,程序员接单,程序员外包平台,程序员外包

    2022年9月29日
    4
  • 工位已备好,来跟我“养龙虾”

    工位已备好,来跟我“养龙虾”

    2026年3月13日
    3
  • 知识表示学习 TransE 代码逻辑梳理 超详细解析

    知识表示学习 TransE 代码逻辑梳理 超详细解析知识表示学习网络上已经存在了大量知识库 KBs 比如 OpenCyc WordNet Freebase Dbpedia 等等 这些知识库是为了各种各样的目的建立的 因此很难用到其他系统上面 为了发挥知识库的图 graph 性 也为了得到统计学习 包括机器学习和深度学习 的优势 我们需要将知识库嵌入 embedding 到一个低维空间里 比如 10 20 50 维 我们都知道 获得了向量后 就可以运用各种数学工具进行分析 它为许多知识获取任务和下游应用铺平了道路 总的来说 废话这么多 所谓知识表示学习 就

    2026年3月18日
    1
  • qt中qmake的详解

    1.首先,感性的认识是,qmake可以利用源文件(包括头文件h,实现文件cpp,qt的ui文件等等)生成各种不同类型的工程,工程需要的Makefile文件,可执行的与不可执行的,这取决于所用的模板(包括app、lib、subdirs、vcapp、vclib)。2.创建pro文件,添加各种源文件,还可以设定平台相关的不同源文件,设置各种规则,利用qmake命令生成工程。后面会介绍pro文件可

    2022年4月3日
    181

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号