51单片机t1定时器3ms
时间: 2023-12-10 10:35:56 浏览: 37
根据引用[2]中提到的时钟周期公式,我们可以计算出51单片机的时钟周期。假设晶振频率为11.0592MHz,则时钟周期为Tosc=1/11.0592MHz=90.518us。要实现3ms的定时器,我们可以使用定时器T1,并将其工作模式设置为16位自动重载模式。具体的编程思路如下:
1.首先需要计算出定时器T1的初值,即定时器计数器的初始值。由于定时器T1是16位的,所以它的计数范围是0~65535。要实现3ms的定时器,需要计算出定时器T1的计数次数。计算公式为:定时器计数次数 = 定时时间 / 定时器时钟周期。将3ms代入公式中,可得定时器计数次数为33.156。由于定时器计数器是整数,所以需要将计数次数向下取整,即取33。
2.计算出定时器T1的重载值。由于定时器T1是16位的,所以它的重载值为65535-33+1=65503。
3.将定时器T1的工作模式设置为16位自动重载模式,并将初值和重载值分别赋给TH1和TL1寄存器。
4.启动定时器T1。
下面是具体的代码实现:
```assembly
MOV TMOD, #0x10 ; 将定时器T1的工作模式设置为16位自动重载模式
MOV TH1, #0xFC ; 将定时器T1的初值设置为65503
MOV TL1, #0x17
SETB TR1 ; 启动定时器T1
```
相关问题
51单片机定时器0和定时器1
51单片机有两个定时器/计数器:定时器0(T0为P3.4)和定时器1(T1为P3.5)。这两个定时器/计数器内部分别有16位计数寄存器,可以用于计时或计数。以下是定时器0的初始化代码示例:
```c
void timer0Init() {
TR0 = 1; // 启动定时器0
TMOD = 0x01; // 定时器模式1,16位定时模式
TH0 = (65535-46082)/256; // 定时50ms
TL0 = (65535-46082)%256;
}
```
其中,TR0为定时器0的启动控制位,TMOD为定时器模式寄存器,TH0和TL0分别为定时器0的高8位和低8位计数寄存器。在上述代码中,定时器0被设置为16位定时模式,定时50ms。
12M晶振51单片机不用定时器毫秒级延时
可以使用循环实现毫秒级延时,但这种方法会占用CPU资源,不太可靠。更好的方法是使用外部中断或者定时器来实现延时。对于12M晶振的51单片机,可以使用定时器来实现毫秒级延时,具体方法如下:
1. 配置定时器T0或T1,将其设置为定时1ms的模式;
2. 在定时器中断服务程序中,设置一个标志位,表示已经过了1ms;
3. 在需要延时的地方,先清除标志位,然后进入一个循环,等待标志位被设置;
4. 当标志位被设置时,表示已经过了1ms,跳出循环,延时完成。
下面是一个示例代码:
```c
#include <reg51.h>
sbit led = P1^0; //定义LED连接的IO口
volatile unsigned int count = 0; //计数器
//定时器中断服务程序
void timer0_isr() interrupt 1
{
count++; //计数器加1
}
//延时1ms
void delay_ms()
{
count = 0; //清零计数器
while(count < 1000); //等待计数器达到1000
}
void main()
{
TMOD = 0x01; //设置定时器T0为模式1
TH0 = 0xFC; //设置定时器T0的初值为0xFC67,定时1ms
TL0 = 0x67;
ET0 = 1; //使能定时器T0中断
EA = 1; //使能总中断
TR0 = 1; //启动定时器T0
while(1)
{
led = 0; //点亮LED
delay_ms(); //延时1ms
led = 1; //熄灭LED
delay_ms(); //延时1ms
}
}
```
在上述代码中,我们使用定时器T0来实现1ms的定时,并在定时器中断服务程序中对一个计数器进行累加。在延时函数中,我们清零计数器,并在一个循环中等待计数器达到1000,即1ms的时间。当计数器达到1000时,跳出循环,延时完成。