单片机几个典型延时函数
单片机延时函数
单⽚机延时函数1.51单⽚机延时,晶振为11.0592MHz(1)粗略延时void delay_ms(uint x){uint i,j;for(i=x;i>0:i--)for(j=110;j>0;j--);}(2)定时器延时void delay_ms(uint i){TMOD=0x01; //设置定时器⼯作模式while(i != 0){TR0=1; //开启定时器TH0=(65535-1000)/256; //赋初值TL0=(65535-1000)%256;while(TF0 != 1); //溢出标志TF0=0;i--;}TR0=0; //关闭定时器}2.stm32l151C8T6延时,外部晶振8MHz(1)粗略延时void delay_us(uint32_t time) //us延时{uint32_t i=4\*time;while(i--);}void delay_us(uint32_t time) //ms延时{uint32_t i=4000\*time;while(i--);}(2)使⽤nop延时通过使⽤__NOP()函数进⾏延时,因为使⽤了8M晶振4倍频,所以是32MHz,所以⼀个nop约等于1/32us,所以使⽤32个nop函数为⼀个us,然后根据需要的定时时间进⾏计算。
void delay_us(uint32_t time) //us延时{uint32_t i=0;for(i=0;i(3)利⽤SysTick延时void delay_init() //初始化{SysTick_CLKSourceConfig(SysTick_CLKSource_HCLK_Div8); //选择外部时钟fac_us=SystemCoreClock/8000000; //为系统时钟的1/8 4fac_ms=1000\*fac_us;}void delay_us(uint16_t nus) //延时us{uint32_t ui_tmp=0x00;SysTick->LOAD=nus\*fac_us;SysTick->VAL=0x00;SysTick->CTRL=0x01;do{ui_tmp=SysTick->CTRL;}while((ui_tmp&0x01) && (!(ui_tmp & (1<<16))));SysTick->CTRL=0x00;SysTick->VAL=0x00;}void delay_ms(uint16_t nms) //延时ms{uint32_t ui_tmp=0x00;SysTick->LOAD=nms\*fac_ms;SysTick->VAL=0x00;SysTick->CTRL=0x01;do{ui_tmp=SysTick->CTRL;}while((ui_tmp&0x01) && (!(ui_tmp&(1<<16))));SysTick->VAL=0x00;SysTick->CTRL=0x00;}void SysTick_Handler(void){flag=~flag;}(4)定时器延时void TIM3_Int_Init(uint16_t arr,uint16_t psc){TIM_TimeBaseInitTypeDef TIM_TimeBaseStructure;NVIC_InitTypeDef NVIC_InitStructure;RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM3,ENABLE);//设置在下⼀个更新事件装⼊活动的⾃动重装载寄存器周期的值,计数10000为1s;TIM_TimeBaseStructure.TIM_Period = arr;//设置⽤来作为TIMx时钟频率除数的预分频值,10kHz的计数频率TIM_TimeBaseStructure.TIM_Prescaler = psc;//设置时钟分割:TDIS = Tck_timTIM_TimeBaseStructure.TIM_ClockDivision = 0;//设置TIM向上计数模式TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;//初始化TIMx的时间基数单位TIM_TimeBaseInit(TIM3,&TIM_TimeBaseStructure);//使能指定的TIM3中断,允许更新中断TIM_ITConfig(TIM3,TIM_IT_Update,ENABLE);//TIM3中断NVIC_InitStructure.NVIC_IRQChannel = TIM3_IRQn;//抢占优先级 0 级NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;//从优先级 3 级NVIC_InitStructure.NVIC_IRQChannelSubPriority = 3;//IRQ通道被使能NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;//初始化外设NVIC寄存器NVIC_Init(&NVIC_InitStructure);//使能TIMx外设TIM_Cmd(TIM3,ENABLE);}void TIM3_IRQHandler(void){if(TIM_GetITStatus(TIM3,TIM_IT_Update) != RESET) //检查指定的TIM中断发⽣与否 {TIM_ClearITPendingBit(TIM3,TIM_IT_Update); //清除TIMx的中断待处理位if(flag==0){flag=1;GPIO_ResetBits(GPIOB,GPIO_Pin_0) ;}else{flag=0;GPIO_SetBits(GPIOB,GPIO_Pin_0);}}}注意:定时时间的计算定时器时钟为:CK_CLK预分频数值:PSC⾃动装载寄存器数值:ARR进⼊中断的次数:timet=time\*(ARR+1)\*(PSC+1)/(CK_CLK)。
51单片机延时函数
51单片机延时函数在嵌入式系统开发中,51单片机因其易于学习和使用、成本低廉等优点被广泛使用。
在51单片机的程序设计中,延时函数是一个常见的需求。
通过延时函数,我们可以控制程序的执行速度,实现定时器功能,或者在需要的时候进行延时操作。
本文将介绍51单片机中常见的延时函数及其实现方法。
一、使用for循环延时这种方法不精确,但是对于要求不高的场合,可以用来估算延时。
cvoid delay(unsigned int time){unsigned int i,j;for(i=0;i<time;i++)for(j=0;j<1275;j++);}这个延时函数的原理是:在第一个for循环中,我们循环了指定的时间次数(time次),然后在每一次循环中,我们又循环了1275次。
这样,整个函数的执行时间就是time乘以1275,大致上形成了一个延时效果。
但是需要注意的是,这种方法因为硬件和编译器的不同,延时时间会有很大差异,所以只适用于对延时时间要求不精确的场合。
二、使用while循环延时这种方法比使用for循环延时更精确一些,但是同样因为硬件和编译器的不同,延时时间会有差异。
cvoid delay(unsigned int time){unsigned int i;while(time--)for(i=0;i<1275;i++);}这个延时函数的原理是:我们先进入一个while循环,在这个循环中,我们循环指定的时间次数(time次)。
然后在每一次循环中,我们又循环了1275次。
这样,整个函数的执行时间就是time乘以1275,大致上形成了一个延时效果。
但是需要注意的是,这种方法因为硬件和编译器的不同,延时时间会有差异,所以只适用于对延时时间要求不精确的场合。
三、使用定时器0实现精确延时这种方法需要在单片机中开启定时器0,并设置定时器中断。
在中断服务程序中,我们进行相应的操作来实现精确的延时。
这种方法需要使用到单片机的定时器中断功能,相对复杂一些,但是可以实现精确的延时。
51单片机延时函数
51单片机延时函数
151单片机延时函数
51单片机是一种常用的微控制器,它可以实现一系列功能,如定时器,定时器中断等。
随着科技的发展,许多人需要使用单片机来实现特定功能,而51单片机是最受欢迎的也是最知名的。
本文旨在介绍51单片机延时函数的实现方法。
1.1时钟
任何有效的51单片机使用的延时函数都受时钟的控制。
由于50单片机本身的频率有限,为了让计算机更有效地运行,我们需要精确设置时钟频率。
由于时钟频率的不同,51单片机的延时函数也有所不同。
1.2延时函数的实现
51单片机的延时函数是用来延迟任务的一种方法。
延时函数可以延迟任务的执行,并且可以按照用户设定的起点和终点执行任务。
51单片机使用指令延时来实现延时函数。
指令延时就是指通过控制51单片机内部时钟,来让程序暂停一段指定时间。
这样,我们就可以实现受时钟控制的延时函数。
1.3延时函数的实际应用
51单片机的延时函数可以用来实现许多不同的功能,如断电保护,延时启动,定时控制等。
由于这些函数可以精确控制任务的执
行,可以适应复杂的工作环境。
同时,51单片机还可以实现节能,使系统能够更加稳定可靠。
2结论
51单片机延时函数是51单片机应用中最基础的功能之一。
该函数可以满足不同用户的需求,帮助产品在实际应用中更好地发挥作用,同时还可以实现节能。
单片机的几种延时函数
C:0x0011EEMOVA,R6//1T
C:0x0012C3CLRC//1T
C:0x00139FSUBBA,DlyT //1T
C:0x00145003JNCC:0019//2T
C:0x00160E INCR6//1T
C:0x001780F8SJMPC:0011//2T 可以看出,0x000F~0x0017一共8条语句,分析语句可以发现并不是每条语句都执行DlyT次。核心循环只有0x0011~0x0017共6条语句,总共8个机器周期,第1次循环先执行“CLR A”和“MOV R6,A”两条语句,需要2个机器周期,每循环1次需要8个机器周期,但最后1次循环需要5个机器周期。DlyT次核心循环语句消耗(2+DlyT×8+5)个机器周期,当系统采用12 MHz时,精度为7 μs。 当采用while (DlyT--)循环体时,DlyT的值存放在R7中。相对应的汇编代码如下: C:0x000FAE07MOVR6, R7//1T
void Dly1ms(void) {
unsigned int i,j;
while (1) {
T_point = 1;
for(i=0பைடு நூலகம்i<2;i++){
for(j=0;j<124;j++){;}
}
T_point = 0;
…
汇编语言程序段
…
#pragma endasm 延时函数可设置入口参数,可将参数定义为unsigned char、int或long型。根据参数与返回值的传递规则,这时参数和函数返回值位于R7、R7R6、R7R6R5中。在应用时应注意以下几点: ◆ #pragma asm、#pragma endasm不允许嵌套使用;
单片机的几种延时函数
摘要实际的单片机应用系统开发过程中,由于程序功能的需要,经常编写各种延时程序,延时时间从数微秒到数秒不等,对于许多C51开发者特别是初学者编制非常精确的延时程序有一定难度。
本文从实际应用出发,讨论几种实用的编制精确延时程序和计算程序执行时间的方法,并给出各种方法使用的详细步骤,以便读者能够很好地掌握理解。
关键词 Ke il C51 精确延时程序执行时间引言单片机因具有体积小、功能强、成本低以及便于实现分布式控制而有非常广泛的应用领域[1]。
单片机开发者在编制各种应用程序时经常会遇到实现精确延时的问题,比如按键去抖、数据传输等操作都要在程序中插入一段或几段延时,时间从几十微秒到几秒。
有时还要求有很高的精度,如使用单总线芯片D S18B20时,允许误差范围在十几微秒以内[2],否则,芯片无法工作。
用51汇编语言写程序时,这种问题很容易得到解决,而目前开发嵌入式系统软件的主流工具为C语言,用C51写延时程序时需要一些技巧[3]。
因此,在多年单片机开发经验的基础上,介绍几种实用的编制精确延时程序和计算程序执行时间的方法。
实现延时通常有两种方法:一种是硬件延时,要用到定时器/计数器,这种方法可以提高CP U的工作效率,也能做到精确延时;另一种是软件延时,这种方法主要采用循环体进行。
1使用定时器/计数器实现精确延时单片机系统一般常选用11.059 2 MH z、12MHz或6 MHz晶振。
第一种更容易产生各种标准的波特率,后两种的一个机器周期分别为1 μs和2 μs,便于精确延时。
本程序中假设使用频率为12 MH z的晶振。
最长的延时时间可达216=65 536μs。
单片机的延时与中断问题及解决方法
单片机的延时与中断问题及解决方法单片机作为嵌入式系统中非常重要的组成部分,在许多应用中都需要进行延时和中断处理。
延时和中断是单片机中常见的问题,它们直接关系到系统的稳定性和性能。
本文将重点介绍单片机中延时和中断的问题,并提出解决方法。
一、延时问题延时是指在程序执行过程中需要暂停一段时间,以便等待某些条件满足或者执行某些特定的操作。
在单片机中,延时通常需要通过软件实现,也就是在程序中加入延时函数。
常见的延时函数包括循环延时和定时器延时。
1. 循环延时循环延时是指通过循环来实现延时的方式。
具体做法是在程序中使用一个循环来反复执行空操作,从而消耗一定的时间。
下面是一个简单的循环延时函数:```cvoid delay(unsigned int ms){unsigned int i, j;for(i = 0; i < ms; i++)for(j = 0; j < 1000; j++);}```这个函数中,外层循环控制延时的毫秒数,内层循环则是用来消耗时间的。
通过这样的方式可以实现一定量级的延时。
循环延时的精度和稳定性都不够理想,特别是在频繁调用的情况下,容易导致系统性能下降。
2. 定时器延时定时器是单片机中常见的外设之一,它可以生成精确的时间延时。
通过设置定时器的时钟源和计数值,可以实现微秒级甚至更小单位的延时。
在单片机中,通常会使用定时器来实现较为精确的延时操作。
下面是一个使用定时器来实现延时的示例:```cvoid delay_us(unsigned int us){TMOD = 0x01; // 设置定时器为工作方式1TH0 = 0xFF - us / 256; // 设置定时器初值TL0 = 0xFF - us % 256; // 设置定时器初值TR0 = 1; // 启动定时器while(!TF0); // 等待定时器溢出TR0 = 0; // 停止定时器TF0 = 0; // 清除溢出标志}```这段代码中,我们使用定时器0来实现微秒级的延时操作。
延时函数——精选推荐
延时函数延时函数1、void delay(void) //两个void意思分别为⽆需返回值,没有参数传递{unsigned int i; //定义⽆符号整数,最⼤取值范围65535for(i=0;i<20000;i++) //做20000次空循环; //什么也不做,等待⼀个机器周期}2、void delay(void){unsigned char i,j;for(i=0;i<250;i++)for(j=0;j<250;j++);}3、void int_delay(void) //延时⼀段较长的时间{unsigned int m; //定义⽆符号整形变量,双字节数据,值域为0~65535for(m=0;m<36000;m++); //空操作}4、void char_delay(void) //延时⼀段较短的时间{unsigned char i,j; //定义⽆符号字符型变量,单字节数据,值域0~255for(i=0;i<200;i++)for(j=0;j<180;j++); //空操作}//*for(a=2;a>0;a--) // 2微秒,执⾏2次(a+2)是4微秒;for(b=142;b>0;b--) // 2微秒,执⾏142次,for(a=2;a>0;a--)是4微秒,即2*(142*4);for(c=1;c>0;c--) // 2微秒, 执⾏1次,即2*(142*4)=1136微秒;b=125,1000/8=125,再减去其它调⽤时间,应该b取值不⼤于125。
追问:这些时间是怎么得出来的?追答:51单⽚机执⾏⼀条指令⼀般是1---3微秒(12MHz),执⾏⼀条减⼀-判断-跳转指令,就是2微秒,这是c语⾔翻译为机器语⾔后的指令,cjne或djnz(汇编语⾔),编译器⽤什么指令和⽅法,需要你⾃⼰试验,我说的只是⼀种。
*//。
51单片机延时函数
C程序中可使用不同类型的变量来进行延时设计。
经实验测试,使用unsigned char类型具有比unsigned int更优化的代码,在使用时应该使用unsigned char作为延时变量。
以某晶振为12MHz 的单片机为例,晶振为12MHz即一个机器周期为1us。
一. 500ms延时子程序程序:void delay500ms(void){unsigned char i,j,k;for(i=15;i>0;i--)for(j=202;j>0;j--)for(k=81;k>0;k--);}计算分析:程序共有三层循环一层循环n:R5*2 = 81*2 = 162us DJNZ 2us二层循环m:R6*(n+3) = 202*165 = 33330us DJNZ2us + R5赋值 1us = 3us三层循环: R7*(m+3) = 15*33333 = 499995us DJNZ 2us + R6赋值1us = 3us循环外: 5us子程序调用2us + 子程序返回 2us + R7赋值 1us = 5us延时总时间= 三层循环+ 循环外= 499995+5 = 500000us =500ms计算公式:延时时间=[(2*R5+3)*R6+3]*R7+5二. 200ms延时子程序程序:{unsigned char i,j,k;for(i=5;i>0;i--)for(j=132;j>0;j --)for(k=150;k>0;k --);}三. 10ms延时子程序程序:{unsigned char i,j,k;for(i=5;i>0;i--)for(j=4;j>0;j--)for(k=248;k>0;k --);}四. 1s延时子程序程序:void delay1s(void){unsigned char h,i,j,k;for(h=5;h>0;h--)for(i=4;i>0;i--)for(j=116;j>0;j --)for(k=214;k>0;k --);}关于单片机C语言的精确延时,网上很多都是大约给出延时值没有准确那值是多少,也就没有达到精确高的要求,而本函数克服了以上缺点,能够精确计数出要延时值且精确达到1us,本举例所用CPU为STC12C5412系列12倍速的单片机,只要修改一下参数值其它系例单片机也通用,适用范围宽。
单片机实现延时方法总结
单片机实现延时方法总结实现延时通常有两种方法:一种是硬件延时,要用到定时器/计数器,这种方法可以提高CPU的工作效率,也能做到精确延时;另一种是软件延时,这种方法主要采用循环体进行。
1 、使用定时器/计数器实现精确延时单片机系统一般常选用11.059 2 MHz、12 MHz或6 MHz晶振。
第一种更容易产生各种标准的波特率,后两种的一个机器周期分别为1 μs和2 μs,便于精确延时。
本程序中假设使用频率为12 MHz的晶振。
最长的延时时间可达216=65 536 μs。
若定时器工作在方式2,则可实现极短时间的精确延时;如使用其他定时方式,则要考虑重装定时初值的时间(重装定时器初值占用2个机器周期)。
在实际应用中,定时常采用中断方式,如进行适当的循环可实现几秒甚至更长时间的延时。
使用定时器/计数器延时从程序的执行效率和稳定性两方面考虑都是最佳的方案。
但应该注意,C51编写的中断服务程序编译后会自动加上PUSH ACC、PUSH PSW、POP PSW和POP ACC语句,执行时占用了4个机器周期;如程序中还有计数值加1语句,则又会占用1个机器周期。
这些语句所消耗的时间在计算定时初值时要考虑进去,从初值中减去以达到最小误差的目的。
2 、软件延时与时间计算在很多情况下,定时器/计数器经常被用作其他用途,这时候就只能用软件方法延时。
下面介绍几种软件延时的方法。
2.1 短暂延时可以在C文件中通过使用带_NOP_( )语句的函数实现,定义一系列不同的延时函数,如Delay10us( )、Delay25us( )、Delay40us( )等存放在一个自定义的C文件中,需要时在主程序中直接调用。
如延时10 μs的延时函数可编写如下:void Delay10us( ) {_NOP_( );_NOP_( );_NOP_( );_NOP_( );_NOP_( );_NOP_( );}Delay10us( )函数中共用了6个_NOP_( )语句,每个语句执行时间为1 μs。
单片机C51延时时间怎样计算
单片机C51延时时间怎样计算
1. 延时函数:C51中提供了一个延时函数`delay(`,可以用来实现简单的延时操作。
该函数的参数为延时的时间,单位是毫秒(ms)。
2.单片机时钟频率:C51的时钟频率一般为12MHz,即每秒钟钟脉冲个数为12,000,000次。
3.定时/计数器模块:C51中的定时/计数器模块可以用来精确控制延时时间。
其中,TMOD寄存器用来设置定时器的工作模式,THx和TLx寄存器用来设置定时器的初值。
4.定时器计数:C51的定时器工作时,会不断地进行计数。
当计数值达到设定的初值时,会触发中断或者产生一个标志位,可以利用这个特性来实现精确的延时操作。
5.延时时间计算公式:延时时间(单位:毫秒)=计数器初值*定时器计数时间/定时器时钟频率
延时时间计算的具体步骤如下:
1.确定延时所需的毫秒数。
2.确定定时器的工作模式。
3.根据定时器的工作模式,设置THx和TLx寄存器的初值。
4.根据定时器的时钟频率和计数器初值,计算延时时间。
延时函数的缺点是,它是通过循环执行一段无用指令来实现延时的,因此在延时期间无法执行其他操作,延时的精度也不够高。
如果需要精确的延时时间,可以利用定时/计数器模块来实现。
51单片机延时函数
51单片机延时函数
51单片机延时函数是51单片机在实际应用中必不可少的一种函数,它的作用是延迟指令的执行,可以让程序运行的更加精确,因此十分重要。
51单片机延时函数可以用来控制时间、分析数据、检测信号、按指定时间触发特定事件等等。
以实际应用为例,如果使用51单片机实现一个报警装置,延时函数可以用来实现报警时间的控制,以及报警过程间隔时间的控制,从而控制不同报警信号的发出。
51单片机延时函数的实现有很多种,比如空循环实现、定时器实现等。
空循环实现的51单片机延时函数,是通过一个无限循环来实现的,这样就可以让程序在循环中计算循环次数,从而实现对时间的控制。
但是,空循环有其局限性,在51单片机运行的环境越来越复杂的今天,空循环实现的51单片机延时函数的灵敏度越来越低,达不到精确控制时间的需要。
另外,定时器实现的51单片机延时函数,是通过51单片机自带的定时器来实现的,定时器实现的51单片机延时函数能够精确控制时间,而且还可以实现多种复杂的功能,比如定时检测信号、定时触发特定事件等。
51单片机延时函数在实际应用中十分重要,有空循环实现和定时器实现两种实现方法,空循环实现的51单片机延时函数简单易实现,但在复杂环境下灵敏度较低;而定时器实现的51单片机延时函数能够精确控制时间,实现复杂功能,但程序复杂度较高。
所以,在51单片机实际应用中,应根据实际情况选择最佳的实现方法。
c51的精确延时
注:1.编译软件为"Keil uVision3"(Keil uVision2也试用)。用其他编译软件的话就不准了。
2.需要包含头文件<intrins.h>
3.所有函数的延时时间都是在12Mhz晶振下计算的,如用其他晶振需进行换算。
4.函数的执行时间为“函数的参数”乘以精确到的时间。例如delayms(unsigned char n)函数,其精确度为1ms,如果写入语句delayms(4),那就是延时4ms。
用c语言为单片机编程无疑十分节约时间,可在很短的时间内开发出较高效的代码,对于程序的维护和扩充也较汇编语言方便许多。
但c语言也有它的不足之处,那就是在时间的精确控制上。要想用c实现精确的延时,只能把c的函数编译成汇编语言,然后按照汇编语言计算其执行时间。本人就按照这种方法,编写了几个51单片机的c语言精确延时函数。
(2)精确到100us的延时(12MHz)
void delay100us(unsigned char n)
{ unsigned char i;
for(;n;n--)
{ _nop_();
for(i=46;i;i--);
}
}
(3)精确的半毫秒延时函数(12MHz)
5.计算出来的延时时间不包括函数调用与返回的时间。如果函数的精确度较高,且参数较小,那么实际延时时间就可能与计算的时间差很远。
(1)精确到2us的延时(12MHz)
void delayus(unsigned char n)
{ while(--n);
}
void delay1_2ms(unsigned char n)
{ unsigned char i;
单片机delay函数用法
单片机delay函数用法1. 引言在单片机编程中,延时函数是一项非常重要的功能。
通过延时函数,我们可以控制程序在执行过程中的时间间隔,以实现各种需要时间控制的功能。
本文将详细介绍单片机中延时函数的用法。
2. 延时函数的原理延时函数的原理是通过软件实现的。
在单片机中,可以使用定时器或循环控制来实现延时功能。
定时器是单片机中的一个硬件模块,通过设置定时器的计数值和时钟源,可以实现精确的定时功能。
而循环控制是通过在程序中加入循环,让程序在指定的时间内空转一段时间,从而实现延时的效果。
3. 延时函数的分类延时函数可以根据其实现的方式进行分类。
常见的延时函数有以下几种:3.1 定时器延时函数定时器延时函数是通过使用定时器模块来实现的。
通过设置定时器的相关参数,可以实现准确的延时功能。
定时器延时函数的优点是精确度高,但需要花费一定的时间和精力来配置定时器。
3.2 循环延时函数循环延时函数是通过在程序中加入循环来实现延时的效果。
循环延时函数的原理是让程序在指定的时间内进行循环,从而实现一段时间的延时。
循环延时函数的优点是简单易实现,但由于程序在延时期间需要不断进行循环,可能会占用较多的处理器资源。
3.3 软件中断延时函数软件中断延时函数是通过使用软件中断的方式实现延时功能。
在延时函数中,可以设置软件中断的定时器,当定时器计数值达到预设值时,触发软件中断,从而实现延时效果。
软件中断延时函数的优点是不需要额外的硬件支持,但在延时期间无法进行其他操作。
4. 常见的延时函数4.1 _delay_ms函数_delay_ms函数是一个常见的延时函数,用于实现以毫秒为单位的延时。
该函数的原型为:void _delay_ms(unsigned int ms);参数ms表示需要延时的毫秒数。
该函数的实现原理是通过循环控制来实现延时的效果。
使用_delay_ms函数时,需要注意以下几点:•延时时间的精确度取决于单片机的主频和循环次数。
单片机的延时与中断问题及解决方法
单片机的延时与中断问题及解决方法一、延时问题在单片机编程中, 经常需要生成一定延时时间, 延时一般实现方式有两种, 一种是软件延时, 另一种是硬件延时。
1. 软件延时软件延时是逐个扫描处理器的时钟脉冲, 每一个时钟周期执行一次循环程序, 每次循环的时间固定。
通过循环次数的控制, 达到延时的目的。
在软件延时期间,程序是被占用的,故需要考虑延时时间尽量短,同时不影响程序的执行。
实现代码:void delay(unsigned int x) //延时函数,x表示延时时间{unsigned int i,j;for(i=0;i<x;i++)for(j=0;j<1000;j++); //短跑}下面的例子是让板载LED在开启1秒、关闭1秒间缓慢闪烁,延时采用软件延时的方式:硬件延迟又称为定时器延迟, 定时器是一个独立的片内设备, 可以独立于CPU运行,定时器的时间不受程序的执行速度和被调用函数的影响, 它运行在一个专用的时钟上面,它具有高可靠性和高精度的特点。
单片机的周期性和准确性都是要靠定时器来完成的。
同时这种方法不影响CPU的其他操作,具有很好的实时性。
二、中断问题中断是单片机的一种重要功能,它可以让CPU在执行某个任务的同时立即执行另一个任务,这种即时响应的能力是单片机的一个最大优点,常常用来响应实时性较高的任务。
微控制器具有中断请求和响应功能的芯片,中断处理器独立于当前CPU的执行,即产生中断时CPU停止执行当前指令,转而执行中断程序处的指令,用完后从停止的地方继续执行当前程序。
根据取决于它们发生的原因,中断可以分为两类:内部中断和外部中断。
中断的优点:相对于软件循环,中断方式的优势主要体现在:实现简单,处理时间短,对CPU的干扰小,实现实时性强。
中断的缺点:1. 中断需要单片机芯片本身支持,若不支持,需通过其他芯片辅助实现。
2. 硬件结构较为复杂,且比较占用IO口。
3. 中断只有在硬件支持的情况下才能使用,所以其可移植性不强。
王伟民老师1T单片机延时函数精选
/***************************************************************
*
* delay.c
*
*
******************************************************************/
void delay500us();
void delay1ms() ;
void delay2ms() ;
void delay5ms() ;
void delay10ms();
void delay20ms();
void delay50ms();
void delay100ms() ;
void delay500ms();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
_nop_();
}
/*******************************************/
/*******************************************/
}
/*******************************************/
/*******************************************/
/*500ms延时*/
void delay500ms()
{
delays(0.5);
}
/*******************************************/
关于单片机C语言的精确延时
for(i = 0; i < 600; i++); } } /********************************************************************************************
/******************************************************************************************** void main (void){ //主程序 while(1){
LED = ~LED; //取LED相反状态 DELAY_MS(1000); //修改这里的数值看看会有什么变化 }
} /******************************************************************************************** - 应用实例
可将其模板下载到本地硬盘,在编写新程序的时候复制、粘贴到工程当 中,然后根据情况写入具体内容。
- 使用说明
data unsigned char cou = 0; // 定义软计数器,放在程序最前面的寄存 器定义部分
/********************************************************************************************
51单片机C程序标准延时函数
51单片机C程序标准延时函数在此,我用的是12M晶振,一个时钟周期是1/12us,一个机器周期为12个时钟周期,则机器周期为1us,而51单片机执行一条语句,为1,2,4个机器周期不等,根据语句的长度来定,一般为1个机器周期。
而_nop_()为一条空语句,执行一次需要一个机器周期。
1us#include<intrins.h>_nop_();执行了一条_nop_();所以延时为1us;10usvoid delay10us(){_nop_();_nop_();_nop_();_nop_();_nop_();_nop_();}执行了6条_nop_(),延时6us,主函数调用delay10us 时,先执行了LCALL指令2us,然后执行6条_nop_()语句6us,最后执行一条RET指令2us,所以总共延时10us。
100usvoid delay100us(){delay10us();delay10us();delay10us();delay10us();delay10us();delay10us();delay10us();delay10us();delay10us();_nop_();_nop_();_nop_();_nop_();_nop_();_nop_();}与上面的一样,主函数调用delay100us();先执行了LCALL语句2us,再调用9个delay10us()函数90us,然后执行了6条_nop_()语句6us,最后执行了一条RET语句2us,总共100us。
1msvoid delay1ms(){f=1;TH0=0xe1;TL0=0X13;TR0=1;while(f);}void T0_3() interrupt 1{TR0=0;f=0;}这里就直接用51单片机内部定时器延时了,如果用_nop_();如果要做到微妙不差,那程序就太长了。
这里我用的是定时器0的方式0,13位定时器,这里为了方便,我就没就EA=1;ET0=1;TM0D=0X00;写在延时函数里。
stc15w4k48s4延时函数
stc15w4k48s4延时函数STC15W4K48S4是一款由深圳市富泰宏微电子有限公司生产的单片机。
该芯片基于8031芯片的核心,在功能上进行了扩展和优化,使其成为一款功能强大、可靠性高的单片机。
其中,STC15W4K48S4延时函数是该单片机中的一个重要功能。
在单片机的程序设计中,经常需要进行一些延时操作,以确保程序能够按照要求执行。
STC15W4K48S4延时函数就是针对这个需求而编写的。
STC15W4K48S4延时函数的实现方法主要有两种。
一种是使用循环来进行延时,即在程序中使用一个循环进行空转,从而达到延时的效果。
另一种是使用定时器来进行延时,即设置一个定时器,并在定时器到达预定时间后进行中断处理。
无论是哪种实现方法,STC15W4K48S4延时函数的使用都非常简单。
首先需要定义延时的时长,然后调用相应的函数即可。
例如,如果需要延时100毫秒,可以使用以下代码:```void delay_ms(unsigned int i){while(i--){delay_us(990);}}void delay_us(unsigned int i){while(i--);}```以上代码定义了两个函数,delay_ms()函数用于实现毫秒级的延时,而delay_us()函数用于实现微秒级的延时。
在delay_ms()函数中,通过循环调用delay_us()函数来实现延时。
delay_us()函数中的while循环会进行i次空转,从而实现了微秒级的延时。
总体来说,STC15W4K48S4延时函数是一款非常实用的单片机功能。
它不仅能够满足程序设计中常见的延时需求,而且还非常简单易用,可以大大提高程序设计的效率和可靠性。
在实际应用中,程序员只需要根据具体的需求选择合适的延时函数,并用适当的参数调用即可。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
软件延时:(asm)
晶振12MHZ,延时1秒
程序如下:
DELAY:MOV 72H,#100
LOOP3:MOV 71H,#100
LOOP1:MOV 70H,#47
LOOP0:DJNZ 70H,LOOP0
NOP
DJNZ 71H,LOOP1
MOV 70H,#46
LOOP2:DJNZ 70H,LOOP2
NOP
DJNZ 72H,LOOP3
MOV 70H,#48
LOOP4:DJNZ 70H,LOOP4
定时器延时:
晶振12MHZ,延时1s,定时器0工作方式为方式1
DELAY1:MOV R7,#0AH ;;晶振12MHZ,延时0.5秒
AJMP DELAY
DELAY2:MOV R7,#14H ;;晶振12MHZ,延时1秒DELAY:CLR EX0
MOV TMOD,#01H ;设置定时器的工作方式为方式1
MOV TL0,#0B0H ;给定时器设置计数初始值
MOV TH0,#3CH
SETB TR0 ;开启定时器
HERE:JBC TF0,NEXT1
SJMP HERE
NEXT1:MOV TL0,#0B0H
MOV TH0,#3CH
DJNZ R7,HERE
CLR TR0 ;定时器要软件清零
SETB EX0
RET
C语言延时程序:
10ms延时子程序(12MHZ)void delay10ms(void)
{
unsigned char i,j,k;
for(i=5;i>0;i--)
for(j=4;j>0;j--)
for(k=248;k>0;k--);
}
1s延时子程序(12MHZ)void delay1s(void)
{
unsigned char h,i,j,k;
for(h=5;h>0;h--)
for(i=4;i>0;i--)
for(j=116;j>0;j--)
for(k=214;k>0;k--);
}
200ms延时子程序(12MHZ)
void delay200ms(void)
{
unsigned char i,j,k;
for(i=5;i>0;i--)
for(j=132;j>0;j--)
for(k=150;k>0;k--);
}
500ms延时子程序程序: (12MHZ)
void delay500ms(void)
{
unsigned char i,j,k;
for(i=15;i>0;i--)
for(j=202;j>0;j--)
for(k=81;k>0;k--);
}
下面是用了8.0000MHZ的晶振的几个延时程序(用定时0的工作模式1):
(1)延时0.9MS
void delay_0_9ms(void)
{
TMOD=0x01; /*定时器0工作在模式1下(16位计数器)*/
TH0=0xfd;
TL0=0xa8;
TR0=1; /*启动定时器*/
while(TF0==0);
TR0=0;
}
(2)延时1MS
void delay_1ms(void)
{
TMOD=0x01; /*定时器0工作在模式1下(16位计数器)*/ TH0=0xfd;
TL0=0x65;
TR0=1; /*启动定时器*/
while(TF0==0);
TR0=0;
}
(3)延时4.5ms
void delay_4_5ms(void)
{
TMOD=0x01; /*定时器0工作在模式1下(16位计数器)*/ TH0=0xf4;
TL0=0x48;
TR0=1; /*启动定时器*/
while(TF0==0);
TR0=0;
}。