51单片机学习日记(5-1)

本文介绍了一种使用模块化编程改进的C语言程序,包括主函数main.c、延时处理Delay.c和Nixie显示函数Nixie.c,展示了如何通过引入延迟函数和定义数组来简化代码。
摘要由CSDN通过智能技术生成

该篇文章主要是对于上一篇的文章中实现功能的另一种改进就是利用了模块化编程的优点使得整个的程序显得简洁。

main.c

#include <REGX52.H>
#include"Delay.h"
#include"Nixie.h"

void main()
{
	while(1)
	{
		Nixie(1,1);	
		Nixie(2,2);
		Nixie(3,3);
		Nixie(4,4);

		
	}
}

Delay.c

void Delay(unsigned int xms)	//@12.000MHz xms为延时长度
{
	unsigned char data i, j;
	while(xms)
	{
		i = 2;
	j = 239;
	do
	{
		while (--j);
	} while (--i);
		xms=xms-1;
	}
	
}


Delay.h

#ifndef __DELAY_H__
#define __DELAY_H__

void Delay(unsigned int xms);
#endif

Nixie.c

#include <REGX52.H>
#include"Delay.h"
unsigned char NixieTable[]={0x3F,0x06,0x5B,0x4F,0x66,0x6D,0x7D,0x07,0x7F,0x6F};//定义数组
void Nixie(unsigned char Location,Number)
{
	switch(Location)
	{
		case 1:P2_4=1;P2_3=1;P2_2=1;//权重分别为4 2 1
		  break;
		case 2:P2_4=1;P2_3=1;P2_2=0;//权重分别为4 2 1
		  break;
		case 3:P2_4=1;P2_3=0;P2_2=1;//权重分别为4 2 1
		  break;
		case 4:P2_4=1;P2_3=0;P2_2=0;//权重分别为4 2 1
		  break;
		case 5:P2_4=0;P2_3=1;P2_2=1;//权重分别为4 2 1
		  break;
		case 6:P2_4=0;P2_3=1;P2_2=1;//权重分别为4 2 1
		  break;
		case 7:P2_4=0;P2_3=0;P2_2=1;//权重分别为4 2 1
		  break;
		case 8:P2_4=0;P2_3=0;P2_2=0;//权重分别为4 2 1
		  break;
	}
	P0=NixieTable[Number];
	Delay(1);
	P0=00;

}

在该函数的编写中运用了Delay函数所以就要同时引用 Delay.h

Nixie.h

#ifndef __NIXIE_H_
#define __NIXIE_H_
void Nixie(unsigned char Location,Number);
#endif

  • 7
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值