实验1 定时器的应用

该实验旨在掌握51单片机定时器原理,利用定时器0或1设置50毫秒周期,使得P2.0引脚每50毫秒输出5毫秒高电平。在第5次周期后,P2.1引脚额外输出10毫秒高电平。实验要求注释TMOD寄存器配置和初值设定,通过实际操作提升理论与实践结合能力,检验学习效果。

开发板推荐:天空星STM32F407VET6开发板

超高性价比 STM32主控 | 超高主频 | 一板兼容百芯 | 比赛神器 | 沉金彩色丝印

实验目的:

  1. 掌握定时器的原理及常用工作方式;
  2. 能够根据特定任务需求选择合适的工作方式实现定时

实验要求:

1、采用51单片机定时器0或定时1实现定时,注释清楚TMOD及初值来源;(40分)s

2、要求定时器每50毫秒P2.0引脚输出一次5毫秒的高电平脉冲;(30分)

3、第5次50毫秒完成后,在P2.0引脚输出5毫秒的高电平脉冲同时在P2.1引脚也输出10毫秒的高电平脉冲。(30分)

 

提交材料:

源代码:

#include "reg52.h"  //此文件中定义了单片机的一些特殊功能寄存器

typedef unsigned int u16;   //对数据类型进行声明定义

typedef unsigned char u8;

sbit led1=P2^0;

sbit led2=P2^1;

u8 n1,n2;

u8 DisplayData[8];



//延时函数,当i=1时,延时10us/

void delay(u16 i)

{

while(i--);

}



//定时器0初始化

void Timer0Init()

{

TMOD|=0X01;//设置定时器0模式为工作方式1(M1M0为01),仅用TR0打开启动。

TH0=(65536-9174)/256; //因初值11.0592M晶振,定时10ms数为9174

TL0=(65536-9174)%256;

ET0=1;//打开定时器0中断允许

EA=1;//打开总中断

TR0=1;//打开定时器

}



void main()

{

Timer0Init();  //定时器0初始化

while(1);

}



//定时器0中断函数

void Timer0() interrupt 1

{

TH0=(65536-9174)/256; //给定时器赋初值,定时10ms数为9174

TL0=(65536-9174)%256;

n1++;

    if(n1==5)//亮led1

{

    led1=0;

delay(500); //亮5ms

led1=1;

}

if(n1>=5)

{

n1=0;

n2++;

if(n2==5)//亮led2

{

led2=0;

delay(1000);//亮10ms

led2=1;

n2=0;

}

}

}

实验心得

通过本次实验设计使我感受到它是一门综合性、实践性较强的课程,使我体,会到要想综合运用所学的理论知识,提高我的设计能力,必须增加实际操作的环节。这次课程设计不仅培养了我们的实际动手能力,更检验了我们对本门课学习的情况,培养我们严肃认真的学习态度。真正做到理论联系实际,提高动手能力和分析问题、解决问题的能力,并能用设计报告表达设计思想和结果的能力正是我这次课程的目的。在定时器计数度器模式寄存器里M1M0:定时/计数器一共有四种工作方式,就是用M1M0来控制的,2位正好是四种组合。我们知道定时器的工作方式1是16位的定时/计数方式,将M1M0设为01即可,其它特性与工作方式0相同。

开发板推荐:天空星STM32F407VET6开发板

超高性价比 STM32主控 | 超高主频 | 一板兼容百芯 | 比赛神器 | 沉金彩色丝印

在ClassWizard中响ID为~Dlg中的WM_TIMER消息。 使用SetTimer(nIDEvent,time,NULL)来建立一个定时器,关闭定时器用KillTimer(nIDEvent)函数。 然后可以响ON_WM_TIMER消息来响一个定时器完成一次后的程序。 响方式如下: void CTimeDlg::OnTimer(UINT nIDEvent) { if(nIDEvent==1000)//间隔为5秒 { //处理事件 } elseif(nIDEvent==1001)//间隔为10秒 { //处理事件 } CDialog::OnTimer(nIDEvent); } 以下是给出一个串口通信定检查接收数据的部分代码 void CMyDlg::OnOpenCom() { // TODO: Add your control notification handler code here if( f_open_com==true ) { f_open_com = false; GetDlgItem(IDC_OPEN_COM)->SetWindowText("打开通信端口"); CloseHandle(hComm); KillTimer(1000); /// 关闭定时器 return ; } SetTimer(1000, 1000, NULL); ///nIDEvent==1000,time=5000ms const char *ComNo; DCB dcb; string temp("COM1"); ComNo = temp.c_str(); hComm = CreateFile( ComNo , GENERIC_READ|GENERIC_WRITE , 0 , NULL , OPEN_EXISTING , 0 , 0); if( hComm==INVALID_HANDLE_VALUE ) /// 如果端口未打开 { MessageBox("打开通信端口出错!" , "Comm Error" , MB_OK); return ; } /// 将dcb地址传入,以取得通信参数 GetCommState(hComm,&dcb); /// 得知目前通信状态 dcb.BaudRate = CBR_9600; dcb.ByteSize = 8; /// 字节为8 dcb.Parity = NOPARITY; /// Parity为None dcb.StopBits = ONESTOPBIT; /// 1个停止位 if( !SetCommState( hComm , &dcb)){ MessageBox("通信端口设置出错!" , "Set Error" , MB_OK ); CloseHandle(hComm); return; } GetDlgItem(IDC_OPEN_COM)->SetWindowText("关闭通信端口"); f_open_com = true; } void CMyDlg::OnTimer(UINT nIDEvent) { // TODO: Add your message handler code here and/or call default char inbuff[1024]; DWORD nBytesRead , dwError; COMSTAT cs; /// 取得状态 ClearCommError( hComm , &dwError , &cs); /// 数据是否大于所准备的缓冲区 if( cs.cbInQue > sizeof(inbuff) ) { PurgeComm(hComm , PURGE_RXCLEAR ); /// 清除通信端口数据 return ; } ReadFile(hComm , inbuff , cs.cbInQue , &nBytesRead , NULL ); //接收通信端口的数据 inbuff[cs.cbInQue] = '\0'; MessageBox("打开通信端口出错!" , "Comm Error" , MB_OK); m_Receive.Format("%s",inbuff); UpdateData(false); CDialog::OnTimer(nIDEvent); } 李杨: for(int i=0; ;i++ ) { ... Sleep(5); if(i>...) {AfxMessageBox("错误XXX"); return;} }//跳出后记得停止一些机器动作
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值