单片机:c语言实现秒表计数(按键开始,结束,重置)

实现秒表计数功能,使用定时器和外部中断实现。8号按键代表计时开始/结束,C号按键代表重置为0,为了演示方便,这里上限定为15秒。

代码中有详细的注释:

#include <reg52.h>

sbit WEI=P2^7;
sbit DUAN=P2^6;
sbit L1=P3^4;

unsigned char code dofly_DuanMa[11]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0x40};// 显示段码值0~9
unsigned char code dofly_WeiMa[]={0xfe,0xfd,0xfb,0xf7,0xef,0xdf,0xbf,0x7f};//分别对应相应的数码管点亮,即位码

void delay(int t)
{
   while(t--);
}

//第一个参数i代表控制第几个数码管,n代表要显示的数字
void Screen(int i,int n)
{

     P0=0;
     DUAN=1;
	 DUAN=0;

     P0=dofly_WeiMa[i];
     WEI=1;
	 WEI=0;

     P0=dofly_DuanMa[n];
     DUAN=1;
     DUAN=0;

}

int sec;
int num;
int i;
int flag;

int main()
{
    flag=1;
    i=0;
    num=0;
	sec=0;
  	WEI=0;
  	DUAN=0;

   //开中断
 	EX0=1;
 	IT0=1;
  	EX1=1;
 	IT1=1;         

    //定时器初始化
    TMOD |= 0x01;
    EA=1;
    ET0=1;
    TR0=1;

   L1=0;

   while(1)
   {

     if(num>=10)
	 Screen(3,num/10);

	 Screen(4,num%10);
     delay(10);
     Screen(5,10);

	 Screen(6,sec/10);
     Screen(7,sec%10);

	}

      return 0;
}

void Timer_0() interrupt 1 using 1
{

   TH0=(65536-10000)/256;
   TL0=(65535-10000)%256;
   if(flag==1)
   {
     i++;

	    sec++;
		if(sec==100) //0.1ms
		sec=0;

     if(i==101)//1s
     {
        i=0;
	    num++;
	    if(num==15)
	    num=0;
     }
   }
}

void ACTION1() interrupt 0
{
    flag=!flag;

}

void ACTION2() interrupt 2
{

	  if(flag==0)
	  {
	    Screen(7,0);
	    num=0;
		sec=0;
	  }
}
时间: 2024-12-31 03:33:20

单片机:c语言实现秒表计数(按键开始,结束,重置)的相关文章

单片机c语言教程:C51循环语句

单片机c语言教程第十三课 C51循环语句 循环语句是几乎每个程序都会用到的,它的作用就是用来实现需要反复进行多次的操 作.如一个 12M 的 51 芯片应用电路中要求实现 1 毫秒的延时,那么就要执行 1000 次空语句 才能达到延时的目的(当然能使用定时器来做,这里就不讨论),如果是写 1000 条空语 句那是多么麻烦的事情,再者就是要占用很多的存储空间.我们能知道这 1000 条空语句, 无非就是一条空语句重复执行 1000 次,因此我们就能用循环语句去写,这样不但使程序 结构清晰明了,而且

单片机脚本语言-移植lua到stm32-MDK

Lua简介 Lua[1]  是一个小巧的脚本语言.作者是巴西人.该语言的设计目的是为了嵌入应用程序中,从而为应用程序提供灵活的扩展和定制功能. Lua脚本可以很容易的被C/C++ 代码调用,也可以反过来调用C/C++的函数,这使得Lua在应用程序中可以被广泛应用.不仅仅作为扩展脚本,也可以作为普通的配置文件,代替XML,Ini等文件格式,并且更容易理解和维护. Lua的目标是成为一个很容易嵌入其它语言中使用的语言.大多数程序员也认为它的确做到了这一点. 很多应用程序使用LUA作为自己的嵌入式脚本

电子时钟万年历+51单片机+1602液晶屏+DS1302+DS18B20+按键

这次课程设计要完成的是制作一个基于51单片机的电子时钟的万年历(protues仿真),需要用到1602液晶屏+DS1302+DS18B20+按键等模块.各个的模块就不在一一介绍,直接讲解这个系统的功能,首先是四个按键,第一个按键是选中需要修改时间位置,在按一次选中下一个,依次类推,第二个按键是对数值进行加一,第三个按键对数值进行减一,第四个按键确认. 先放仿真图 然后是代码: main.c #include <REG52.H> #include <intrins.h> #defin

单片机C语言探究--为什么变量最好要赋初值

有许多书上说,变量最好要赋初值.但是为什么要初值呢?不赋初值可能会出现什么样的意外呢?以下就我在以51单片机为MCU,Keil为编译器看到的实现现象作分析.众所周知,变量是存储在RAM中,掉电后即丢失,上电后默认全为0.那么这样的话没赋初值的变量值全为0,这也应该是大家认为理所当然的.但是,当单片机复位的时候(包括硬件复位即按下复位按钮,看门狗复位,以及其它软件程序复位),单片机只是重新跳回到main函数开始执行,而并没有清空RAM!所以,那些只是定义而没有赋初值的变量(尤其是全局变量)依然会使

单片机C语言延时需注意的问题

标准的C语言中没有空语句.但在单片机的C语言编程中,经常需要用几个空指令产生短延时的效果.这在汇编语言中很容易实现,写几个nop就行了. 在keil C51中,直接调用库函数: #include // 声明了void _nop_(void); _nop_(); // 产生一条NOP指令 作用:对于延时很短的,要求在us级的,采用“_nop_”函数,这个函数相当汇编NOP指令,延时几微秒.NOP指令为单周期指令,可由晶振频率算出延时时间,对于12M晶振,延时1uS.对于延时比较长的,要求在大于10

单片机第6课:独立按键检测原理

将JP5的8号引脚连接到单片机的P1^0,然后P1^0和发光二极管的接正引脚相连接(加高电平,发光二极管就会亮,由于单片机上电的时候各IO口默认为高电平,所以导线接好之后,发光二极管就点亮了).当我们按下K1的时候,发光二极管熄灭,松开按键,发光二极管再次点亮.因为当你按下按键的时候,TTL电路只有两种电平的时候,呈现"线与"的关系,再次检测P1^0引脚的电平,你会发现已经是低电平了.因为高电平与上低电平等于低电平.

单片机C语言的程序架构

初学单片机时,都会纠结于其各个模块功能的应用,如串口(232,485)对各种功能IC的控制,电机控制PWM,中断应用,定时器应用,人机界面应用,CAN总线等. 这是一个学习过程中必需的阶段,是基本功.很庆幸,在参加电子设计大赛赛前培训时,MCU周围的控制都训练的很扎实.经过这个阶段后,后来接触不同的MCU就会发现,都大同小异,各有各的优势而已,学任何一种新的MCU都很容易入手包括一些复杂的处理器.而且对MCU的编程控制会提升一个高度概况--就是对各种外围进行控制(如果是对复杂算法的运算就会 用D

下位机单片机c语言发送数据到串口,上位机pc机java语言获取端口数据

环境: Windows7 64b,jdk64b,myeclipse8.5,rxtx开发包,STC,keil,格西烽火,51单片机,rs232USB转串口线. 下位机c代码 #include <reg51.h> #include <string.h> #define INBUF_LEN 7   //数据长度 unsigned char inbuf1[INBUF_LEN]; unsigned char checksum,count3,count=0; bit           rea

单片机第7课:独立按键消抖程序

JP3连接P0口,数码管的VCC接+5V电源,JP5的8.1分别接P2.0和P2.1. #include<reg51.h> /* * 功能:独立按键消除抖动程序,按下KEY1,数值加1,按下KEY8,数值减去1 * */ #define uchar unsigned char #define uint unsigned int int num; uchar code table[] = {0xc0, 0xf9, 0xa4, 0xb0, 0x99, 0x92, 0x82, 0xf8, 0x80,