经典句子

51

| 点击:

【www.pindukj.com--经典句子】

篇一:51单片机中断号

若51单片机使用C语言编程,51单片机中断号的排列顺序是按中断向量地址由低到高来排列中断号,不是按中断查询的优先级或者中断服务顺序的优先级来排列中断号的。

本内容简单介绍了C51单片机的中断号以及中断向量,方便大家了解和学习

关键词:中断向量C51单片机

一、中断号

二、interrupt 和 using 在C51中断中的使用

8051 系列 MCU 的基本结构包括:32 个 I/O 口(4 组8 bit 端口);两个16 位定时计数器;全双工串行通信;6 个中断源(2 个外部中断、2 个定时/计数器中断、1 个串口输入/输出中断),两级中断优先级

;128

字节内置RAM;独立的 64K 字节可寻址数据和代码区。中断发生后,MCU 转到 5 个中断入口处之一,然后执行相应的中断服务处理程序。中断程序的入口地址被编译器放在中断向量中,中断向量位于程序代码段的最低地址处,注意这里的串口输入/输出中断共用一个中断向量。8051的中断向量表如下:

C51单片机的中断号以及中断向量

C51单片机的中断号以及中断向量

一、中断号

外部中断00

定时器T0 1

外部中断12

定时器T1 3

串口中断 4

二、interrupt 和 using 在C51中断中的使用

8051 系列 MCU 的基本结构包括:32 个 I/O 口(4 组8 bit 端口);两个16 位定时计数器;全双工串行通信;6 个中断源(2 个外部中断、2 个定时/计数器中断、1 个串口输入/输出中断),两级中断优先级;128 字节内置RAM;独立的 64K 字节可寻址数据和代码区。中断发生后,MCU 转到 5 个中断入口处之一,然后执行相应的中断服务处理程序。中断程序的入口地址被编译器放在中断向量中,中断向量位于程序代码段的最低地址处,注意这里的串口输入/输出中断共用一个中断向量。8051的中断向量表如下:

中断源 中断向量 上电复位 0000H 外部中断0 0003H 定时器0 溢出 000BH 外部中断1 0013H 定时器1 溢出 001BH 串行口中断 0023H 定时器2 溢出 002BH

51单片机定时器中断号 电梯直达

发表于 2013-11-10 23:37:34 | 只看该作者

有用的中断号知识

void表示函数类型

interrupt 0 ←这里的0表示中断源编号

using 1 ←这里的1表示选用的寄存器组别

在MCS-51单片机中,单片机类型不同,中断源个数也有差别.例如8051有5

个中断源,8052有6个中断源.现以8051为例

中断源 中断服务入口地址中断标志

外部中断INT0 0003H IE0

定时器T0 000BHTF0

外部中断INT1 0013H IE1| |

定时器T1 001BH TF1 串行口TI/RI 00023H TI/RI中断优先级别从上到下依次降低 interrupt 表示中断优先级,using表示所用工作寄存器组。 interrupt x using y 跟在interrupt 后面的xx 值得是中断号,就是说这个函数对应第几个中断端口,一般在51中 0 外部中断0 1 定时器0 2 外部中断1 3 定时器1 4 串行中断其它的根据相应得单片机有自己的含义,实际上c在编译的时候就是把你这个函数的入口地址放到这个对应中断的跳转地址 using y 这个y是说这个中断函数使用的那个寄存器组就是51里面一般有4个 r0 -- r7寄存器,如果你的终端函数和别的程序用的不是同一个寄存器组则进入中断的时候就不会将寄存器组压入堆栈返回时也不会弹出来,节省代码和时间 void intsvr0(void) interrupt 0 using 1 定时/计数器T0 void timer0(void) interrupt 1 using 1 外部中断INT1 void intsvr1(void) interrupt 2 using 1 定时/计数器T1 void timer1(void) interrupt 3 using 1 串口中断 void serial0(void) interrupt4 using 1

篇二:51单片机实例35个

1. 闪烁灯

1. 实验任务

如图4.1.1所示:在P1.0端口上接一个发光二极管L1,使L1在不停地一亮一

灭,一亮一灭的时间间隔为0.2秒。

2. 电路原理图

图4.1.1

3. 系统板上硬件连线

把“单片机系统”区域中的P1.0端口用导线连接到“八路发光二极管指示模块”

区域中的L1端口上。

4. 程序内容

(1). 延时程序的设计方法

作为单片机的指令的执行的时间是很短,数量大微秒级,因此,我们要

求的闪烁时间间隔为0.2秒,相对于微秒来说,相差太大,所以我们在

执行某一指令时,插入延时程序,来达到我们的要求,但这样的延时程

序是如何设计呢?下面具体介绍其原理:

如图4.1.1所示的石英晶体为12MHz,因此,1个机器周期为1微秒

机器周期 微秒

MOV R6,#20 2个 2

D1: MOV R7,#248 2个 2 2+2×248=498 20

×

DJNZ R7,$ 2个 2×248 (498

DJNZ R6,D1 2个2×20=40

10002

因此,上面的延时程序时间为10.002ms。

由以上可知,当R6=10、R7=248时,延时5ms,R6=20、R7=248时,

延时10ms,以此为基本的计时单位。如本实验要求0.2秒=200ms,10ms

×R5=200ms,则R5=20,延时子程序如下:

DELAY: MOV R5,#20

D1: MOV R6,#20

D2: MOV R7,#248

DJNZ R7,$

DJNZ R6,D2

DJNZ R5,D1

RET

(2). 输出控制

如图1所示,当P1.0端口输出高电平,即P1.0=1时,根据发光二极管

的单向导电性可知,这时发光二极管L1熄灭;当P1.0端口输出低电平,

即P1.0=0时,发光二极管L1亮;我们可以使用SETB P1.0指令使P1.0

端口输出高电平,使用CLR P1.0指令使P1.0端口输出低电平。

5.程序框图

如图4.1.2所示

图4.1.2

6. 汇编源程序

ORG 0

START: CLR P1.0

LCALL DELAY

SETB P1.0

LCALL DELAY

LJMP START

DELAY: MOV R5,#20 ;延时子程序,延时0.2秒

D1: MOV R6,#20

D2: MOV R7,#248

DJNZ R7,$

DJNZ R6,D2

DJNZ R5,D1

RET

END

7. C语言源程序

#include <AT89X51.H>

sbit L1=P1^0;

void delay02s(void) //延时0.2秒子程序

{

unsigned char i,j,k;

for(i=20;i>0;i--)

for(j=20;j>0;j--)

for(k=248;k>0;k--);

}

void main(void)

{

while(1)

{

L1=0;

delay02s();

L1=1;

delay02s();

}

2. 模拟开关灯

1. 实验任务

如图4.2.1所示,监视开关K1(接在P3.0端口上),用发光二极管L1(接

在单片机P1.0端口上)显示开关状态,如果开关合上,L1亮,开关打开,

L1熄灭。

2. 电路原理图

图4.2.1

3. 系统板上硬件连线

(1). 把“单片机系统”区域中的P1.0端口用导线连接到“八路发光二极管指示模块”

区域中的L1端口上;

(2). 把“单片机系统”区域中的P3.0端口用导线连接到“四路拨动开关”区域中的

K1端口上;

4. 程序设计内容

(1). 开关状态的检测过程

单片机对开关状态的检测相对于单片机来说,是从单片机的P3.0端口输入信号,

而输入的信号只有高电平和低电平两种,当拨开开关K1拨上去,即输入高电平,

相当开关断开,当拨动开关K1拨下去,即输入低电平,相当开关闭合。单片机

篇三:51单片机程序简单详解

#include<reg52.h> //头文件 后面不加; 定义了单片机所有常用到的地址 sbit d1=P1^0; //位定义 定义P1口的0位为d1 后面加;

void main()//主函数 后面不加;

{

d1=0; //输出P1口0位为低电平 后面加;

while(1);//一个完整程序必须得有始有终 程序停止

}

#include<reg52.h>//头文件

sbit d1=P1^0; //位定义

unsigned int a; //定义无符号整形的变量,变量名随便写

void main() //主函数

{

while(1) //程序须有始有终,首先进入大循环,以防出乱

{

a=50000;//给a赋值

d1=0; //给d1低电平 (点亮LED)

while(a--);//a自减1 共减完到a所赋的值 达到延时的目的

a=50000;//给a赋值

d1=1; //给d1高电平 (熄灭LED)

while(a--);//a自减1 共减完到a所赋的值 达到延时的目的

}

}

#include<reg52.h>

#define a unsigned int //宏定义 定义a,在工程当中所用的a就代表了unsigned int #define b unsigned char //宏定义 定义b,在工程当中所用的b就代表了unsigned char sbit d1=P1^0;

void cnm(); //在主函数之前要声名子函数,加;

void main()

{

while(1) // while(1)是个死循环,始终都在执行它内部的语句

{

d1=0; //输出低电平(点亮LED)

cnm(); // 调用子程序,直接写子函数的函数名 作延时用

d1=1; //输出高电平(熄灭LED)

cnm();// 调用子程序,直接写子函数的函数名 作延时用

}

}

void cnm() //void代表:无返回值,()空的!代表无参数 cnm代表子函数函数名(函数名可以任意取) 子程序=子函数

{

a x,y; //定义两个变量 在一个子函数当中定义的变量称为局部变量 局部变量只在当前的函数当中有效

for(x=100;x>0;x--) //for循环(见资料) 第一个for后面不加大括号的时候,只有下面的第一条认为是它内部的语句

for(y=2000;y>0;y--);//后面所加;代表这条语句是在前一条for语句内部执行的 这种方式为嵌套

}

#include<reg52.h>//头文件

#define a unsigned int //宏定义 定义a,在工程当中所用的a就代表了unsigned int #define b unsigned char //宏定义 定义b,在工程当中所用的b就代表了unsigned char sbit d1=P1^0;

void cnm(a); //在主函数之前要声名子函数, 在参数当中要写上参数的类型 带多个参数时用,隔开 参数名可写可不写 后面加;

void main()

{

while(1) // while(1)是个死循环,始终都在执行它内部的语句

{

d1=0; //输出低电平(点亮LED)

cnm(200); // 调用子程序,直接写子函数的函数名 ()内参数方便修改,作延时用d1=1; //输出高电平(熄灭LED)

cnm(200);// 调用子程序,直接写子函数的函数名 ()内参数方便修改,作延时用 }

}

void cnm(a z) //void代表:无返回值,()内带东西!即带参数 cnm代表子函数函数名(函数名可以任意取) 子程序=子函数

{

a x,y; //定义两个变量 在一个子函数当中定义的变量称为局部变量 局部变量只在当前的函数当中有效

for(x=100;x>0;x--) //for循环(见资料P88) 第一个for后面不加大括号的时候,只有下面的第一条认为是它内部的语句

for(y=z;y>0;y--);//后面所加;代表这条语句是在前一条for语句内部执行的 这种方式为嵌套

}

本文来源:http://www.pindukj.com/jingdianjuzi/24903/