c51程序的基本结构图,单片机c51程序结构有哪几种

首页 > 实用技巧 > 作者:YD1662024-01-16 13:22:10

图1-6 P0口读引脚时的流程图

第二种情况是读锁存器,通过打开读锁存器三态缓冲器读取锁存器输出端Q的状态。如图1-7所示为P0口读锁存器时的流程图。

c51程序的基本结构图,单片机c51程序结构有哪几种(9)

图1-7 P0口读锁存器时的流程图

在输入状态下,从锁存器和从引脚上读取的信号一般是一致的,但也有例外。例如,当从内部总线输出低电平后,锁存器Q=0,

c51程序的基本结构图,单片机c51程序结构有哪几种(10)

=l,场效应管V2开通,端口线呈低电平状态,此时无论端口线上外接的信号是低电平还是高电平,从引脚读入单片机的信号都是低电平,因而不能正确地读入端口引脚上的信号。又如,当从内部总线输出高电平后,锁存器Q=1,

c51程序的基本结构图,单片机c51程序结构有哪几种(11)

=0,场效应管V2截止,如果外接引脚信号为低电平,从引脚上读入的信号就与从锁存器读入的信号不同。为此,8031单片机在对端口P0~P3的输入操作有如下约定:凡属于读—改—写方式的指令,从锁存器读入信号,其他指令则从端口引脚线上读入信号。读—改—写指令的特点是,从端口输入(读)信号,在单片机内加以运算(修改)后,再输出(写)到该端口上。下面是几条读—改—写指令的示例。

ORL P0, A P0→AP0

INC P1 P1 1→P1

DEC P3 P3-1→P3

CPL P2 P2→P2

这样安排的原因在于读—改—写指令需要得到端口原输出的状态,修改后再输出,读锁存器而不是读引脚,可以避免因外部电路的原因使原端口的状态被读错。

注意: P0端口是8031单片机的总线口,分时出现数据D7~D0、低8位地址A7~A0以及三态,用来连接存储器、外部电路与外部设备。P0端口是使用最广泛的I/O端口。

(2)作为地址/数据复用口使用时的工作原理

在访问外部存储器时,P0口作为地址/数据复用口使用,这时多路开关控制信号为l,与门解锁,与门输出信号电平由地址/数据线信号决定;多路开关与反相器的输出端相连,地址信号经地址/数据线→反相器→V2场效应管栅极→V2漏极输出。例如,控制信号为l,地址信号为0时,与门输出低电平,Vl管截止;反相器输出高电平,V2管导通,输出引脚的地址信号为低电平。如图1-8所示为P0口作为地址线,控制信号为1,地址信号为0时的工作流程图。

c51程序的基本结构图,单片机c51程序结构有哪几种(12)

上一页12345下一页

栏目热文

文档排行

本站推荐

Copyright © 2018 - 2021 www.yd166.com., All Rights Reserved.