51单片机简单功能的实现(2)

这篇博客主要介绍了51单片机中的一些基本功能实现,包括延时函数、流水灯效果、蜂鸣器结合流水灯的应用,以及数码管的显示和有规律的动态显示。还涉及外部中断程序的编写,六位数码管显示,按键消抖处理,按键与数码管的交互,以及串口通讯和读写功能。对于理解和实践51单片机的基础操作非常有帮助。
摘要由CSDN通过智能技术生成

51单片机简单功能的实现(2)

延时函数外加闪烁

#include<reg52.h>
#define uint unsigned int
#define uchar unsigned char
sbit D1=P1^0;
//void delay();
void delay(uint);
void main()
{
   
	while(1)
	{
   
		D1=0;
		delay(600);
		D1=1;
		delay(600);
	}
}

/*void delay()
{
	uint x,y;
	for(x=100;x>0;x--)
		for(y=600;y>0;y--);
}*/
void delay(uint z)
{
   
	uint x,y;
	for(x=100;x>0;x--)
		for(y=z;y>0;y--);	

}

流水灯

#include<reg52.h>
#include <intrins.h>
#define uint unsigned int
#define uchar unsigned char
uchar temp;
void delay(uint);
void main()
{
   
	temp=0xfe;
	P1=temp;
	while(1)
	{
   
		temp=_crol_(temp,1);
		delay(600);
		P1=temp;
	}
}

void delay(uint z)
{
   
	uint x,y;
	for(x=100;x>0;x--)
		for(y=z;y>0;y--);	

}

流水灯结合蜂鸣器

#include<reg52.h>
#include <intrins.h>
#define uint unsigned int
#define uchar unsigned char
uchar temp;
sbit beep=P2^3;
void delay(uint);
void main()
{
   
	temp=0xfe;//11111110
	P1=temp;
	beep=0;
	while(1)
	{
   
		temp=_crol_(temp,1);  //_cror_循环右移
		delay(600);
		P1=temp;
	}
}

void delay(uint z)
{
   
	uint x,y;
	for(x=100;x>0;x--)
		for(y=z;y>0;y--);	

}

第一个数码管的显示

#include<reg52.h>
sbit dula=P2^6;
sbit wela=P2^7;

void main()
{
   
	wela=1;
	P0=0xfe; //P0=0xfc;	//P0=0xc0;
	wela=0;

	dula=1;
	P0=0x06; //P0=0x3f;
	dula=0;
	while(1);

}

数码管的有规律显示

#include<reg52.h>
#define uint unsigned int
#define uchar unsigned char
sbit dula=P2^6;
sbit wela=P2^7;
uchar num;
uchar code table[]={
   
0x3f,0x06,0x5b,0x4f,
0x66,0x6d,0x7d,0x07,
0x7f,0x6f,0x77,0x7c,
0x39,0x5e,0x79,0x71
};
void delay(uint z);
void main()
{
   
	wela=1;	//11101010
	P0=0xc0;//P0=0xea;
	wela=0;
	while(1)
	{
   
		for(num=0;num<16;num++)
		{
   
			dula=1;
			P0=table[num];
			dula=0;
			delay(1000);	
		}
	}

}
void delay(uint z)
{
   
	uint x,y;
	for(x=100;x>0;x--)
		for(y=z;y>0;y--);	

}

外部中断程序(1)

#include<reg52.h>
#define uint unsigned int
#define uchar unsigned char
sbit dula=P2^6;
sbit wela=P2^7;
sbit d1=P1^0;
uchar num;
uchar code table[]={
   
0x3f,0x06,0x5b,0x4f,
0x66,0x6d,0x7d,0x07,
0x7f,0x6f,0x77,0x7c,
0x39,0x5e,0x79,0x71
};
void delay(uint z);
void main()
{
   
	EA=1; //开总中断
	EX0=1;//开外部中断0
	//IT0=1
	//TCON=0x11;灯闪一下就没
	wela=1;	//11101010
	P0=0xc0;//P0=0xea;
	wela=0;
	while(1)
	{
   
		for(num=0;num<16;num++)
		{
   
			dula=1;
			P0=table[num];
			dula=0;
			delay(1000);	
		}
	}

}
void delay(uint z)
{
   
	uint x,y;
	for(x=100;x>0;x--)
		for(y=z;y>0;y--);	

}

void exter0() interrupt 0
{
   
	d1=0;
}

外部中断程序(2)

#include<reg52.h>//外部中断程序
#define uint unsigned int
#define uchar unsigned char
sbit dula=P2^6;
sbit wela=P2^7;
sbit d1=P1^0;
uchar num,tt;
uchar code table[]=
  • 2
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Capsule。

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值