2013-06-19 15:19:31 dcx1205 阅读数 9501

解释一:

单片机的 IO 口 (输入/输出 口),是相对单片机 本身 而言的,
就是单片机IO口往外输出信号1或者0( 1 的输出电圧 = VCC , 0 的电圧 = 0 V )
或者 单片机从 IO 口 读取 输入 信息 1 或者 0

 

解释二:

1、I/O口的输出是对电流而言的,高电平输出就是输出(或拉出)电流,低电平输出就是输入(或灌入)电流,一般C51单片机1状态为高电平状态,电压接近于电源电压(5V),0状态为低电平状态接近0伏;我们在应用其输出功能时,首先就要在设计上保证I/O口输出高电平时电压不能降低,因其拉电流能力及其微弱,所以高电平输出时一般只用于MOS元件或TTL接口的控制,另外,I/O口的低电平输出时,要保证灌入的电流不超过芯片的要求,否则也不能正常工作。
2、I/O口的输入是对电压而言的,一般当口上电压高于2V时,单片机会作为高电平采如,低于0.8V是单片机会认为是低电平,至于高低电平的电压究竟时多少,各系列芯片或有差异。
3、至于“那么是不是IO上接的东西不一样给IO口在输出为高或低状态的数值也是不一样的”是这样,不管让单片机I/O口接上什么东西,都要通过限流分压等方式来保证I/O口输出的电压值为5V或0,这要变了就会失控的。

 

解释三:

对于IO口,
I是input,输入
O是out, 输出
输出是,设定这个脚为输出,读取这个脚的状态值的话,1为高电压,0为低电平。
输出一般是驱动一个小东西,再带动一个大装置来达到自己想要的要求。
输出你可以看做一个电源。能给你的东西供电。就象电源不会随你会接的东西影响,它始终都是电源。只是有状态,有电,没电。。负载太大的话,只能说是驱动不起来。它输出的状态没变。设计时肯定要避免负载过大的。
输入就像是接受端。你给我电,单片机就会知道,输入端是1,你不给我电,输入端是0。

解释四:

I/O口即通用输出输出口,I/O口只能出入或者输出0和1,0对应低电平,1对应高电平,如果是3.3V系统,高电平就为3.3,如果为5V,那高电平就为5V,低电平为0V。
    如果做输出口的话,就是单片机通过软件置位相关寄存器让端口置高电平或低电平,达到电平输出的目的。
    如果做输入口,就是单片机捕捉端口的电平然后置位相关寄存器,然后软件读取寄存器中0或1,达到输入作用。这是很通俗的理解,如果想更深的了解可以参考通用I/O的结构。
 
注:以上内容来自互联网,各位网友的回答,本人只稍微做了整理。相信上面几个解释总有一个适合你的胃口吧!

 

2011-08-24 11:05:39 xiaoweiboy 阅读数 52957

单片机I/O口推挽输出与开漏输出的区别(转)  


推挽输出:可以输出高,低电平,连接数字器件;

开漏输出:输出端相当于三极管的集电极. 要得到高电平状态需要上拉电阻才行. 适合于做电流型的驱动,其吸收电流的能力相对强(一般20ma以内).
推挽结构一般是指两个三极管分别受两互补信号的控制,总是在一个三极管导通的时候另一个截止.

我们先来说说集电极开路输出的结构。集电极开路输出的结构如图1所示,右边的那个三极管集电极什么都不接,所以叫做集电极开路(左边的三极管为反相之用,使输入为“0”时,输出也为“0”)。对于图1,当左端的输入为“0”时,前面的三极管截止(即集电极C跟发射极E之间相当于断开),所以5V电源通过1K电阻加到右边的三极管上,右边的三极管导通(即相当于一个开关闭合);当左端的输入为“1”时,前面的三极管导通,而后面的三极管截止(相当于开关断开)。

单片机IO口设置推挽和开漏的区别 - 冷水泡茶 - 冷水泡茶

我们将图1简化成图2的样子。图2中的开关受软件控制,“1”时断开,“0”时闭合。很明显可以看出,当开关闭合时,输出直接接地,所以输出电平为0。而当开关断开时,则输出端悬空了,即高阻态。这时电平状态未知,如果后面一个电阻负载(即使很轻的负载)到地,那么输出端的电平就被这个负载拉到低电平了,所以这个电路是不能输出高电平的。

再看图三。图三中那个1K的电阻即是上拉电阻。如果开关闭合,则有电流从1K电阻及开关上流过,但由于开关闭其它三个口带内部上拉),当我们要使用输入功能时,只要将输出口设置为1即可,这样就相当于那个开关断开,而对于P0口来说,就是高阻态了。

对于漏极开路(OD)输出,跟集电极开路输出是十分类似的。将上面的三极管换成场效应管即可。这样集电极就变成了漏极,OC就变成了OD,原理分析是一样的。

另一种输出结构是推挽输出。推挽输出的结构就是把上面的上拉电阻也换成一个开关,当要输出高电平时,上面的开关通,下面的开关断;而要输出低电平时,则刚好相反。比起OC或者OD来说,这样的推挽结构高、低电平驱动能力都很强。如果两个输出不同电平的输出口接在一起的话,就会产生很大的电流,有可能将输出口烧坏。而上面说的OC或OD输出则不会有这样的情况,因为上拉电阻提供的电流比较小。如果是推挽输出的要设置为高阻态时,则两个开关必须同时断开(或者在输出口上使用一个传输门),这样可作为输入状态,AVR单片机的一些IO口就是这种结构。

 

开漏电路特点及应用


     在电路设计时我们常常遇到开漏(open drain)和开集(open collector)的概念。
  所谓开漏电路概念中提到的“漏”就是指MOSFET的漏极。同理,开集电路中的“集”就是指三极管的集电极。开漏电路就是指以MOSFET的漏极为输出的电路。一般的用法是会在漏极外部的电路添加上拉电阻。完整的开漏电路应该由开漏器件和开漏上拉电阻组成。如图1所示:  

单片机I/O口推挽输出与开漏输出的区别(转) - lastnight1034 - lastnight1034的博客

                                图1


组成开漏形式的电路有以下几个特点:
       1. 利用外部电路的驱动能力,减少IC内部的驱动(或驱动比芯片电源电压高的负载)。当IC内部MOSFET导通时,驱动电流是从外部的VCC流经R pull-up ,MOSFET到GND。IC内部仅需很下的栅极驱动电流。如图1。

2. 可以将多个开漏输出的Pin,连接到一条线上。形成 “与逻辑” 关系。如图1,当PIN_A、PIN_B、PIN_C任意一个变低后,开漏线上的逻辑就为0了。这也是I2C,SMBus等总线判断总线占用状态的原理。如果作为输出必须接上拉电阻。接容性负载时,下降延是芯片内的晶体管,是有源驱动,速度较快;上升延是无源的外接电阻,速度慢。如果要求速度高电阻选择要小,功耗会大。所以负载电阻的选择要兼顾功耗和速度。
       3. 可以利用改变上拉电源的电压,改变传输电平。如图2, IC的逻辑电平由电源Vcc1决定,而输出高电平则由Vcc2(上拉电阻的电源电压)决定。这样我们就可以用低电平逻辑控制输出高电平逻辑了(这样你就可以进行任意电平的转换)。(例如加上上拉电阻就可以提供TTL/CMOS电平输出等。)

单片机I/O口推挽输出与开漏输出的区别(转) - lastnight1034 - lastnight1034的博客

      图2

4. 开漏Pin不连接外部的上拉电阻,则只能输出低电平(因此对于经典的51单片机的P0口而言,要想做输入输出功能必须加外部上拉电阻,否则无法输出高电平逻辑)。一般来说,开漏是用来连接不同电平的器件,匹配电平用的。
       5. 标准的开漏脚一般只有输出的能力。添加其它的判断电路,才能具备双向输入、输出的能力。


       6.正常的CMOS输出级是上、下两个管子,把上面的管子去掉就是OPEN-DRAIN了。这种输出的主要目的有两个:电平转换、线与。

7.线与功能主要用于有多个电路对同一信号进行拉低操作的场合,如果本电路不想拉低,就输出高电平,因为OPEN-DRAIN上面的管子被拿掉,高电平是靠外接的上拉电阻实现的。(而正常的CMOS输出级,如果出现一个输出为高另外一个为低时,等于电源短路。)

8.OPEN-DRAIN提供了灵活的输出方式,但是也有其弱点,就是带来上升沿的延时。因为上升沿是通过外接上拉无源电阻对负载充电,所以当电阻选择小时延时就小,但功耗大;反之延时大功耗小。所以如果对延时有要求,则建议用下降沿输出。

应用中需注意:
             1.   开漏和开集的原理类似,在许多应用中我们利用开集电路代替开漏电路。例如,某输入Pin要求由开漏电路驱动。则我们常见的驱动方式是利用一个三极管组成开集电路来驱动它,即方便又节省成本。如图3。

单片机I/O口推挽输出与开漏输出的区别(转) - lastnight1034 - lastnight1034的博客


             2. 上拉电阻R pull-up的阻值决定了逻辑电平转换的沿的速度。阻值越大,速度越低功耗越小。反之亦然。


   Push-Pull输出就是一般所说的推挽输出,在CMOS电路里面应该较CMOS输出更合适,因为在CMOS里面的push-pull输出能力不可能做得双极那么大。输出能力看IC内部输出极N管P管的面积。和开漏输出相比,push-pull的高低电平由IC的电源低定,不能简单的做逻辑操作等。push-pull是现在CMOS电路里面用得最多的输出级设计方式。

当然open drain也不是没有代价,这就是输出的驱动能力很差。输出的驱动能力很差的说法不准确,驱动能力取决于IC中的末级晶体管功率。OD只是带来上升沿的延时,因为上升沿是通过外接上拉无源电阻对负载充电的,当电阻选择小时延时就小、但功耗大,反之延时大功耗小。OPEN DRAIN提供了灵活的输出方式,但也是有代价的,如果对延时有要求,建议用下降沿输出。

电阻小延时小的前提条件是电阻选择的原则应在末级晶体管功耗允许范围内,有经验的设计者在使用逻辑芯片时,不会选择1欧姆的电阻作为上拉电阻。在脉冲的上升沿电源通过上拉无源电阻对负载充电,显然电阻越小上升时间越短,在脉冲的下降沿,除了负载通过有源晶体管放电外,电源也通过上拉电阻和导通的晶体管对地 形成通路,带来的问题是芯片的功耗和耗电问题。电阻影响上升沿,不影响下降沿。如果使用中不关心上升沿,上拉电阻就可选择尽可能的大点,以减少对地通路的 电流。如果对上升沿时间要求较高,电阻大小的选择应以芯片功耗为参考。


2019-03-06 10:40:57 imxlw00 阅读数 98

P1口为例

点亮LED

在这里插入图片描述
点亮led灯,如果让灯点亮,引脚必须低电平。
P1口输出0,内部总线写0,Q非为1,场效应管导通,意味着单片机端口接地,led灯形成回路,灯就亮了。
在这里插入图片描述

LED灯灭

在这里插入图片描述
P1口输出1,内部总线写1,Q非为0,场效应管截止,通过内部的上拉电阻,单片机端口为高,灯就灭了。
在这里插入图片描述

输入

要想把外部的状态读进去,需要对端口先置1,
外部接了一个按键,按键没有按下,通过上拉电阻,引脚读进去高电位,当按键按下,读进去是低电位。
在这里插入图片描述

2019-03-02 16:31:56 imxlw00 阅读数 428

I/O 口基本特性

51 系列单片机有 4 个 8 位并行 I/O 接口,并行就是所有各位数据同时并排传输的方式,每一个接口都有数据输出锁存器、输入缓冲器和输出驱动器。锁存器作为特殊的寄存器属于端口,具有端口地址。每一个接口只有一个端口,对单片机而言就不再区分两者,我们把 4 个接口和其中的锁存器都统一标记为 P0~P3,简称为P0 口、P1口、P2 口和 P3 口。所有端口都可以作为通用输入/输出口,部分还具有特定功能。

在 4 个并行 I/O 端口中,P0 口输出可驱动 8 个 LSTTL(低功耗肖特基 TTL)门,其它端口只能驱动 4 个 LSTTL。以 AT89S51 为例,其 I/O 口输入电流不超过 20mA,输出电流不超过 1.2mA。

P0 口结构

P0 口(P0.0~P0.7,第 39~32 引脚):其中一位的结构如图 所示。P0 口是漏极开路的 8 位并行端口,作双向 I/O 口使用或者作为地址总线低 8 位/数据总线使用。
在这里插入图片描述
用作通用 I/O 口时,T1 截止,同时使转换开关接通 b 点,输出驱动级工作在漏级开路方式,用作输出口,需要外接上拉电阻(通常为 10KΩ);作为输入时,数据可以来自端口的锁存器,也可以来自端口引脚,读引脚时必须先向锁存器中写入1

作为地址总线低 8 位或者数据总线使用时,先输出低 8 位地址,后作为双向数据
总线使用,此时需要外接地址锁存器。

输出 0,T2 导通,引脚 P0 接地,电平为 0;
输出 1,T2 截止,,端口为高阻,要外接上拉电阻,端口才有 5V;

P1 口结构

P1 口(P1.0~P1.7,第 1~8 引脚):内部结构如图所示。P1 口的第一功能是作为准双向 I/O 口使用,由用户程序进行定义。请大家思考一下为什么称准双向口?(是由于接口内部有拉高电路)。作为输出时,无需外接上拉电阻,每个引脚可驱动 4 LSTTL 门电路。做输入口时,必须先向锁存器写“1”。
在这里插入图片描述
输出 0,T2 导通,引脚 P0 接地,电平为 0;
输出 1,T2 截止,电源通过上拉电阻引脚上,电平为 5V;

P2 口结构

P2 口(P2.0~P2.7,第 21~28 引脚):内部结构如图所示。P2 口作为一般的准双向 I/O 口使用或者高 8 位地址总线输出引脚。
在单片机系统仅使用地址的低 8 位,P2 口仍然可以作为通用 I/O 口使用,此时为准双向口。
当系统需要在片外扩展程序存储器或者数据存储器超过 256B 时, P2 口用作地址总线高 8 位。
在这里插入图片描述

P3 口结构

P3 口(P3.0~P3.7,第 10~17 引脚):内部结构如图所示。内部有上拉电阻,P3 口可作为准双向 I/O 口使用或者第二功能引脚,第二功能应用非常重要,其功能描述如表 所示。
在这里插入图片描述
在这里插入图片描述

2017-08-27 15:02:10 LiuStephen 阅读数 742

51单片机的I/O口

1,51单片机的I/O类型为准双向通用I/O。
2,[准双向I/O口] 在用作输入前,必须先用输出指令置锁存器的置为1。
3,[准双向I/O口] 准双向I/O口输出类型可用作输出和输入功能时,不需要重新配置口线输出状态。
4,[准双向I/O口] 当I/O引脚悬空时,该引脚被上拉为高电平。
5,[准双向I/O口] 当I/O口线寄存器为1,且引脚本身为1时,为了把引脚拉低,需要足够的灌电流能力使引脚上的电压降到门槛电压以下。
6,[准双向I/O口] 当I/O口线由0到1跳变时,只需约2个时钟就能够将引脚上拉到高电平。
7,[开漏输出] P0口上电复位后处于开漏输出,当P0管脚作I/O时,需外加10K-4.7K的上拉电阻(I/O口通过一电阻连接到VCC)。
8,[开漏输出]  当外部有上拉电阻,开漏的I/O口还可以读外部状态。
9,对I/O口的设置,在软件设置由低变高后,加1-2个空操作指令延时,再读取数据。
10,驱动LED发光二极管,应当加上1000欧姆的限流电阻(470欧姆以上)。

单片机 通用I/O口

阅读数 848

没有更多推荐了,返回首页