单片机c语言XBYTE的使用

发布者:泥匠手最新更新时间:2017-01-19 来源: eefocus关键字:单片机  c语言  XBYTE 手机看文章 扫描二维码
随时随地手机看文章

大家都知道一般的并行扩展总线---地址总线,数据总线和控制总线一般是相互独立的。但单片机由于受引脚的限制,P0口为低8位地址/数据复用口。其读写时序符合intel8080控制时序。使用外部扩展时,wrrd 等控制引脚不需要特殊配置,只使用指令来区分是否访问外部扩展的存储空间或者外部io设备。当使用 movx等这样的指令时,单片机就会自动产生扩展总线做需要的时序。不需要编程者编程实现。但是,有一个问题就是,使用c语言编程的时候,怎么才能使编译出来的程序含有movx这样的指令那?或者说怎么用c语言书写外部扩展总线的程序那?

 

使用keil 开发单片机程序时,在absacc.h 这个头文件中,有XBYTE这样一个宏。它的定义是 #define XBYTE ((unsignedchar volatile xdata *) 0)

可以使用XBYTE去访问外部的RAM,也可以用XBYTE去访问扩展的I/0设备

注意:这里是利用的英特尔总线进行访问的,那么就会有时序的问题,在C语言中,这些都帮你做完了,所以无需考虑

3、关于I/O的控制如下,低字节表示的是P0端口,高字节表示的是P2端口。P2端口通常作为控制端口,而P0通常作为数据端口

eg:XBYTE[0x8800] = buz_stu;

其中用P2做控制,P0的数据就是buz_stu的状态

 

下面说说这个[]里的偏移量的数值怎么定义。tag:#define XBYTE ((unsignedchar volatile xdata *) 0) XBYTE是一个指针,且值为0,表示的是地址0。XBYTE[56],表示的也就是地址56,和#define TEST ((unsignedchar volatile xdata *) 56)这样定义并使用是一样的,在C语言中,数组名就代表首地址。

关于这个问题,如果你扩展的是RAM的话,首先利用p0和p2口发送16位的地址,然后再往此地址读或者写数据。如果你使用外部的io设备,你就利用单片机的先发地址的特性,利用p2口做控制信号,p0口做数据信号。偏移量的值,我们举个例子来说明。

现有这样一个外部io器件,有相应的rd wr 引脚,另外还需要一个C/D控制信号(C/D引脚为高电平时,数据总线接受指令,为低电平时接受数据)。这样的话,很明显,这个外部io器件可以使用总线方式进行控制。Rd wr 分别接到单片机的rd wr 引脚。还有一个控制引脚C/D,我们把它接到单片机的p2.0口。(还记得说控制io器件时,p2口做控制口了吧)。当然,p0口做数据口。好了,硬件连线介绍完毕!那怎么用c语言进行控制硬件那。

#define DP XBYTE[0xfeff]                // 数据口

#define CP XBYTE[0xffff]                // 命令口

我们以向外部io设备发送数据为例分析一下偏移量怎么算的。

把0xfeff展开成二进制形式   1111 1110 1111 1111  (低字节表示的是P0端口,高字节表示的是P2端口,还记得,哈)我们主要是控制p2.0口在传送总线数据时是低电平就行了,其他的控制信号,我们并不关心,所以p2口的最低位保证为0,其他位是什么都行。不过,赋值时保证不影响控制就行。我们这里不需要的位全部用的1  。

其实,这个偏移量就是外部存储或者io设备的地址。

DP=5;表示的含义就是把5送到外部0xfeff这个地址里存储起来。只是,所需的读写时序由单片机自己产生,先送出地址信号,由p2 p0组成,然后再通过p0口送数据。这里,我们使用了这个特性,用p2口作为外部io设备的控制信号。因为只用p0口是复用的,p2口的状态不变,正好作为控制信号。

 

 

另外,附上我在网上搜的资料。

【实例】

         百度结果:这个主要是在用C51的P0,P2口做外部扩展时使用,其中XBYTE[0x0002],P2口对应于地址高位,P0口对应于地址低位。一般P2口用于控制信号,P0口作为数据通道。

        如:P2.7接WR,P2.6接RD,P2.5接CS,那么就可以确定个外部RAM的一个地址,想往外部RAM的一个地址写一个字节时,地址可以定为XBYTE[0x4000],其中WR,CS为低,RD为高,那就是高位的4,当然其余的可以根据情况自己定,然后通过
XBYTE [0x4000] = 57。这赋值语句,就可以把57写到外部RAM的0x4000处了,此地址对应一个字节。

【汇总】

1、The XBYTE macro accesses individual bytes in theexternal data memory of the 8051. You may use this macro in your programs asfollows:

#include  

. . . 

rval = XBYTE [0x0002];

 XBYTE [0x0002] = 57;

 . . .

This example reads and writes the contents of the byte inexternal data memory at address 0002h.

The range of valid index values for this macro is 0-65535.

(以上为官方定义)

2、在中的定义是

#define XBYTE ((unsigned char volatile xdata *) 0)

可以使用XBYTE去访问外部的RAM,也可以用XBYTE去访问扩展的I/0设备

注意:这里是利用的英特尔总线进行访问的,那么就会有时序的问题,在C语言中,这些都帮你做完了,所以无需考虑

3、关于I/O的控制如下,低字节表示的是P0端口,高字节表示的是P2端口。P2端口通常作为控制端口,而P0通常作为数据端口

eg:XBYTE[0x8800] = buz_stu;

其中用P2做控制,P0的数据就是buz_stu的状态

 

【疑问和解答】

一下摘自论坛网友的问答:

问:

在一般的读写外部RAM的程序中,经常看到这样的句子:

    XBYTE[address]=data   写数据

    data=XBYTE[address]   读数据

但是我想问的是,为什么用了XBYTE后,就不用顾及其时序了呢?

就是说,读写数据的时候,WR和RD怎么都不用用程序去控制了呢?

参考了很多读写外部RAM的程序,都找不到其控制WR和RD控制线的语句

哪位大侠能帮忙解释一下这是为什么嘛?

最好还能说说XBYTE具体的用法.....

答:

外部总线,

1外部总线由3组总线组成,数据 地址 控制,我们常常一般就叫他外部总线,既然是有3组不同的信号,那么他们是怎么协调工作的呢?一般情况CPU有特殊的外部数据访问指令如你这里讲51的MOVX指令(在C语言中他会编译成这个指令)在执行这个指令的时候3组线是协调工作

mov dptr,#1000h

mov a,#55h

movx @dptr,a

上面3调语句的C语言可以表示如下

#define  W_DATA  XBYTE[0x1000]

W_DATA=0X55;

在使用外部总线的时候,数据 地址和控制信号是直接按照规定的时序输出高低电平的,所以不用你管,当然你必须要满足时序工作

一下摘自网友博客文章:

如何理解#define XBYTE ((unsigned char volatile xdata *

8051 特有的内存型态 

code    以 MOVC @A+DPTR读取的程序内存
data    可以直接存取的内部数据存储器
idata    以 Mov @Rn存取的内部数据存储器
bdata    可以位寻址(Bit Addressable)的内部存储器
xdata    以 MOVX @DPTR存取的外部数据存储器
pdata    以 MOVX @Rn存取的外部数据存储器

特殊资料型态 

bit    一般位(bit)变量
sbit    绝对寻址的位(bit)变量
语法
sbit    my_flag    =    location;    (location范围从 0x00 ~ 0x7F)
范例
sbit    EA =    0xAF;
或是配合 bdata 宣告的位(bit)变量
char    bdata        my_flags;
sbit    flag0 =      my_flags ^ 0;
(注意 sbit 前不可以加 static)

sfr    特殊功能缓存器(Special FunctionRegister)
语法
sfr    my_sfr    =    location;    (location范围从 0x80 ~ 0xFF)
范例
sfr    P0    =    0x80;
指定绝对地址的变量 
在单一模块内可以使用下面的语法宣告
[memory_space]    type    variable_name   _at_    location
范例
pdata        char    my_pdata   _at_    0x80;
如果该变量必须为多个模块所使用(Global Variable)则以
抽象指针(Abstract Pointer)的方式在标头档(HeaderFile)定义较为方便。

#define    variable_name    *((data_type *)       location)
范例
#define    my_pdata    *((char pdata *)    0x80)
(注意 char与 pdata的顺序)
ABSACC.H 提供了下列方便的宏(Macro)定义。 
#define CBYTE ((unsigned char volatile code *) 0)
#define DBYTE ((unsigned char volatile data *) 0)
#define PBYTE ((unsigned char volatile pdata *) 0)
#define XBYTE ((unsigned char volatile xdata *) 0)
#define CWORD ((unsigned int volatile code *) 0)
#define DWORD ((unsigned int volatile data *) 0)
#define PWORD ((unsigned int volatile pdata *) 0)
#define XWORD ((unsigned int volatile xdata *) 0)

隐藏的初始化程序 
80C51 在电源重置后(Power On Reset)所执行的第一个程序模块并不是使用者的主程序 
main(),而是一个隐藏在 KEIL-C51标准链接库中称为 startup.a51的程序模块。
startup.a51 的主要工作是把包含 idata、xdata、pdata在内的内存区块清除为 0,并
且初始化递归指针。接着 startup.a51被执行的仍然是一个隐藏在 KEIL-C51标准链接库
中称为 init.a51的程序模块。而 init.a51的主要工作则是初始化具有非零初始值设定的
变量。 
在完成上述的初始化程序之后,80C51的控制权才会交给 main()开始执行使用者的程序。
#define XBYTE ((unsigned char volatile xdata *) 0)
定义    XBYTE为指向 xdata地址空间unsigned char数据类型的指针,指针值为0
这样,可以直接用XBYTE[0xnnnn]或*(XBYTE+0xnnnn)访问外部RAM了

 

 

#include//绝对地址处理头文件,包含XBYTE,用XBYTE来定义扩展的IO端口及外部RAM单元地址, 用XBYTE定义的目的是将外部电路不同的功能编程不同的地址而已这样就可以在程序里面通过直接对地址附置,就能使外部电路实现需要的功能,这样做还有一个好处就是在编译的时候会产生MOVX 指令,这样可以操作WR和RD引脚(像我这个实验图2中,的WR和WD分别接各自对应的WR和WD,所以在执行读写的时候是有单片机自动完成时序控制的),以实现特定的功能,至于用XBYTE定义的地址是多少就得根据实际的外围电路的连接来确定,不是随便写的.

#define uchar unsigned char //宏定义

#define uint unsigned int   //宏定义

#define PA XBYTE[0xfcff]//定义PA端口,为什么这样写呢,我后面会有详细的介绍,有还是不懂的请在帖子下方留言,直接问我我不回回答的!!!

#define PB XBYTE[0xfdff]//定义PB端口

#define PC XBYTE[0xfeff]//定义PC端口

#define PD XBYTE[0xffff]//定义设置寄存器端口

 

sbit A0=P2^0;//定义8255端口地址引脚A0

sbit A1=P2^1;//定义8255端口地址引脚A1

sbit dat=P0;//8255的D0~D7的数据口

void delay(uint ms)   //1ms延时

{

    uint i,j;

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

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

}

void main()

{

    PD=0x80;//方式控制字,端口ABC都工作于方式0,基本输入输出

    PA=0x55;

    PB=0xaa;

    PC=0x55;

while(1)

    {

       PA=~PA;//按位取反,如果这句写成PA=!PA会怎么样?还是和PA=~PA效果一样的吗?自己动手试下

       PB=~PB;//按位取反

       PC=~PC;//按位取反

       delay(120);//延时

   }      

}

 

图1


 


 


 

图2 

 


#define PB XBYTE[0xfdff]//定义PB端口

#define PC XBYTE[0xfeff]//定义PC端口

#define PD XBYTE[0xffff]//定义设置寄存器端口

我到现在还没有说到底为什么这样写,首先还是申明这不是乱写的,从图2连接图可知,CS已经是是使能状态,所以就拿0xfdff为例吧,先展开1111,1101,1111,1111.他们是分别与单片机的P2口和P0口对应的(因为P0P2的第二功能就是外扩展存储器的地址分别代表A0,A1…A15共16位地址,2^16=65536bit/1K=64KB,故最大寻址为64KB),在这里所有的无关位都设为1(也可以设为0,也可以设为X,X代表0和1),也就是保证A1与A0为01即可.同理PC为11,故写成了e.下面的我都是从网上复制过来的,要是不好可别骂我哦!!!当然看不懂还是可以问我.

 

XBYTE是一个地址指针(可当成一个数组名或数组的首地址),它在文件absacc.h中由系统定义,指向外部RAM(包括I/O口)的0000H单元,XBYTE后面的中括号的0xfdff是指数组首地址0000H的偏移地址,即用XBYTE[0xfdff]可访问偏移地址为0xfdff的I/O端口。
     这个主要是在用C51的P0,P2口做外部扩展时使用,其中XBYTE[0xfdff],P2口对应于地址高位,P0口对应于地址低位。一般P2口用于控制信号,P0口作为数据通道。
   比如:P2.7接WR,P2.6接RD,P2.5接CS,那么就可以确定个外部RAM的一个地址,想往外部RAM的一个地址写一个字节时,地址可以定为XBYTE[0x4000],其中WR,CS为低,RD为高,那就是高位的4,当然其余的可以根据情况自己定,然后通过
XBYTE [0x4000] = 57;
这赋值语句,就可以把57写到外部RAM的0x4000处了,此地址对应一个字节。
XBYTE 的作用,可以用来定义绝对地址,是P0口和P2口的,其中P2口对应的是高位,P0口对应的是低位 
如XBYTE[0x1234] = 0x56; 
则等价于 
mov dptr,#1234h 
mov @dptr,#56h

 

 

XBYTE的使用收藏

XBYTE

The XBYTE macro accesses individual bytes in theexternal data memory of the 8051. You may use this macro in your programs asfollows:

 

#include     /*Include Macro Definitions */

rval = XBYTE [0x0002];

XBYTE [0x0002] = 57;

This example reads and writes the contents ofthe byte in external data memory at address 0002h.

The range of valid index values for this macrois 0-65535.

http://www.keil.com/support/man/docs/c51/c51_xbyte.htm

 

    百度结果:这个主要是在用C51的P0,P2口做外部扩展时使用,其中XBYTE[0x0002],P2口对应于地址高位,P0口对应于地址低位。一般P2口用于控制信号,P0口作为数据通道。

 

       如:P2.7接WR,P2.6接RD,P2.5接CS,那么就可以确定个外部RAM的一个地址,想往外部RAM的一个地址写一个字节时,地址可以定为XBYTE[0x4000],其中WR,CS为低,RD为高,(WR,CS,RD都是低电平有效)那就是高位的4,当然其余的可以根据情况自己定,然后通过

XBYTE [0x4000] = 57。这赋值语句,就可以把57写到外部RAM的0x4000处了,此地址对应一个字节。

 

 

 

一下摘自论坛网友的问答:

 

问:

 

在一般的读写外部RAM的程序中,经常看到这样的句子:

 

   XBYTE[address]=data   写数据

 

   data=XBYTE[address]   读数据

 

但是我想问的是,为什么用了XBYTE后,就不用顾及其时序了呢?

 

就是说,读写数据的时候,WR和RD怎么都不用用程序去控制了呢?

 

参考了很多读写外部RAM的程序,都找不到其控制WR和RD控制线的语句

 

哪位大侠能帮忙解释一下这是为什么嘛?

 

最好还能说说XBYTE具体的用法.....

答:

外部总线,

 

1外部总线由3组总线组成,数据 地址 控制,我们常常一般就叫他外部总线,既然是有3组不同的信号,那么他们是怎么协调工作的呢?一般情况CPU有特殊的外部数据访问指令如你这里讲51的MOVX指令(在C语言中他会编译成这个指令)在执行这个指令的时候3组线是协调工作

 

mov dptr,#1000h

 

mov a,#55h

 

movx @dptr,a

 

上面3调语句的C语言可以表示如下

 

#define  W_DATA  XBYTE[0x1000]

 

W_DATA=0X55;

 

在使用外部总线的时候,数据 地址和控制信号是直接按照规定的时序输出高低电平的,所以不用你管,当然你必须要满足时序工作

 

一下摘自网友博客文章:

如何理解#define XBYTE ((unsigned char volatile xdata *

8051 特有的内存型态

 

code    以MOVC @A+DPTR 读取的程序内存

data    可以直接存取的内部数据存储器

idata    以 MOV@Rn 存取的内部数据存储器

bdata    可以位寻址(BitAddressable)的内部存储器

xdata    以MOVX @DPTR 存取的外部数据存储器

pdata    以MOVX @Rn 存取的外部数据存储器

 

特殊资料型态

 

bit    一般位(bit)变量

sbit    绝对寻址的位(bit)变量

语法

sbit   my_flag=location;    (location 范围从0x00 ~ 0x7F)

范例

sbit    EA =0xAF;

或是配合 bdata 宣告的位(bit)变量

char    bdata   my_flags;

sbit    flag0 = my_flags ^ 0;

(注意 sbit 前不可以加 static)

 

sfr    特殊功能缓存器(SpecialFunction Register)

语法

sfr    my_sfr=location;    (location 范围从0x80 ~ 0xFF)

范例

sfr    P0= 0x80;

指定绝对地址的变量

在单一模块内可以使用下面的语法宣告

[memory_space]   type    variable_name    _at_   location

范例

pdata       char    my_pdata    _at_    0x80;

如果该变量必须为多个模块所使用(Global Variable)则以

抽象指针(Abstract Pointer)的方式在标头档(Header File)定义较为方便。

 

#define   variable_name    *((data_type*)        location)

范例

#define    my_pdata   *((char pdata *)    0x80)

(注意 char 与 pdata 的顺序)

ABSACC.H 提供了下列方便的宏(Macro)定义。

#define CBYTE ((unsigned char volatile code *)0)

#define DBYTE ((unsigned char volatile data *)0)

#define PBYTE ((unsigned char volatile pdata *)0)

#define XBYTE ((unsigned char volatile xdata *)0)

#define CWORD ((unsigned int volatile code *) 0)

#define DWORD ((unsigned int volatile data *) 0)

#define PWORD ((unsigned int volatile pdata *)0)

#define XWORD ((unsigned int volatile xdata *)0)

 

隐藏的初始化程序

80C51 在电源重置后(Power On Reset)所执行的第一个程序模块并不是使用者的主程序

main(),而是一个隐藏在 KEIL-C51 标准链接库中称为startup.a51 的程序模块。

startup.a51 的主要工作是把包含 idata、xdata、pdata在内的内存区块清除为 0,并

且初始化递归指针。接着 startup.a51 被执行的仍然是一个隐藏在KEIL-C51 标准链接库

中称为 init.a51 的程序模块。而 init.a51 的主要工作则是初始化具有非零初始值设定的

变量。

在完成上述的初始化程序之后,80C51 的控制权才会交给 main() 开始执行使用者的程序。

#define XBYTE ((unsigned char volatile xdata *)0)

定义    XBYTE 为指向xdata 地址空间unsignedchar 数据类型的指针,指针值为0

这样,可以直接用XBYTE[0xnnnn]或*(XBYTE+0xnnnn)访问外部RAM了

 

XBYTE定义的是外部地址,这样才能和接到你的IO口上的器件通信用XBYTE定义的目的是将外部电路不同的功能编程不同的地址而已这样就可以在程序里面通过直接对地址附置,就能使外部电路实现需要的功能,这样做还有一个好处就是在编译的时候会产生 MOVX 指令,这样可以操作WR和RD引脚,以实现特定的功能至于用XBYTE定义的地址是多少就得根据实际的外围电路的连接来确定,不是随便写的


关键字:单片机  c语言  XBYTE 引用地址:单片机c语言XBYTE的使用

上一篇:写单片机程序数据类型相关
下一篇:单片机掉电模式与空闲模式

推荐阅读最新更新时间:2024-03-16 15:31

51单片机系列连载2—美丽的发光二极管
今天简单地介绍一下发光二极管,发光二极管看似简单,但是在市场中也有很多应用。比如说,在大家经常使用的充电器就有发光二极管的应用,如下图所示: 这就是简易充电器电路,其中LED也就是发光二极管既起到半波整流的作用又兼做指示灯。同样的原理,发光二极管还可以给灯具开关做指示灯、给工业设备配电箱做指示灯以及用共阴极双色LED对电源插座指示等等。 接下来,简单地说一下c语言程序。 大体而言,可以采用位操作与总线操作两种方式写程序,比如让第一个发光二极管亮: (1)、位操作 (2)总线操作 #inc
[单片机]
什么是单片机的时钟周期
时钟周期也称为振荡周期,定义为时钟脉冲的倒数(可以这样来理解,时钟周期就是单片机外接晶振的倒数,例如12M的晶振,它的时间周期就是1/12 us),是计算机中最基本的、最小的时间单位。 在一个时钟周期内,CPU仅完成一个最基本的动作。对于某种单片机,若采用了1MHZ的时钟频率,则时钟周期为1us;若采用4MHZ的时钟频率,则时钟周期为250us。由于时钟脉冲是计算机的基本工作脉冲,它控制着计算机的工作节奏(使计算机的每一步都统一到它的步调上来)。显然,对同一种机型的计算机,时钟频率越高,计算机的工作速度就越快。但是,由于不同的计算机硬件电路和器件的不完全相同,所以其所需要的时钟周频率范围也不一定相同。我们学习的8051单片机的
[单片机]
基于单片机的LED显示数字电压表
 1 引言   单片机是一种集成电路芯片,随着计算机在社会领域的渗透, 单片机的应用正在不断地走向深入,同时带动传统控制检测日新月益更新。在实时检测和自动控制的单片机应用系统中,单片机往往是作为一个核心部件来使用,仅单片机方面知识是不够的,还应根据具体硬件结构,以及针对具体应用对象特点的软件结合,以作完善。由于单片机具有简单实用、高可靠性、良好的性能价格比以及体积小等优点,已经在各个技术领域得到了迅猛发展。数字电压表(Digital Voltmeter)简称DVM,它是采用数字化测量技术,把连续的模拟量(直流输入电压)转换成不连续、离散的数字形式并加以显示的仪表。传统的指针式电压表功能单一、精度低,不能满足数字化时代的需求,采用
[工业控制]
基于<font color='red'>单片机</font>的LED显示数字电压表
STC单片机用键盘控制二极管亮灭的问题
  #include reg52.h   sbit key1=P3^4;   sbit p10=P1^0;   void main()   {   while(1)   {   p10=1;   while(key1!=0);   p10=0;   }   }   我的目的是用键盘控制一个二极管的发光,按下键盘上的键后二极管发光,放开后二极管熄灭。用 while(key1!=0); 进行判断的话,程序工作正常:开始二极管熄灭,按下键盘上的对应按键后二极管被点亮。可是如果用 if(key1!=0); 进行判断的话,程序就会异常:二极管开始时候就亮了,按键盘上的键也没有任何反应。请问这是怎么回事呢?以前写一些小程
[单片机]
STM8单片机启动流程彻底探究--基于IAR开发环境
初学STM8会发现,STM8官方的固件库并没有提供一个.s文件的启动代码,那么她是如何启动然后跳转到main函数执行的呢 首先,我们根据ARM的只是可以推测,STM8也是通过复位向量来启动的,假设流程在复位响亮中完成的,应该首先去复位向量表中间去找,看复位向量又要看存储器映射,一环扣一环 STM8使用的是统一编址技术,以下是存储器编址图 我们可以看到,最大取指空间是0XFFFFFF,也就是说,是16M,这是因为PC的特性决定的 在程序内部,它是将16M分为了256个节(sector),每个节的大小为64K,64*256= 16384K=16M,由图我们可以看到,在SECTOR0区间里面似乎还有些玄妙,之后的就是普通
[单片机]
STM8<font color='red'>单片机</font>启动流程彻底探究--基于IAR开发环境
单片机控制的密码锁设计
单片机控制的密码锁设计。AT89S52单片机P1引脚外接独立式按键S1-S8,分别代表数字键0-5、确定键、取消键。单片机从P3.0-P3.3输出4个信号,分别为1个电磁开锁驱动信号和密码错误指示、报警输出、已开锁指示信号,分别用发光二极管L1-L4指示。P3.4接一有源蜂鸣器,用于实现提示音。 基本要求: (1)初始密码为123450,输完后按确定键开锁,取消键清除所有输入,每次按键有短“滴”声按键提示音。 (2)密码输入正确后,输出一个电磁锁开锁信号与已开锁信号,并发出两声短“滴”声提示。4秒后开锁信号与已开锁指示清零。 (3)密码输入错误时,发出一声长“滴”声错误指示提示音,并密码错误指示灯亮,三次密码错误时,发出长鸣声报警,
[单片机]
<font color='red'>单片机</font>控制的密码锁设计
51单片机上拉电阻
1、51单片机的P0口为了实现准3态,采用了OC输出,也就是集电极悬空输出,也有叫图腾柱输出的。这种电路结构,只有下拉能力,高电平输出没有电流,在高电平时表现为高阻态;加上上拉电阻,就会失去高阻态,变成 1、0 两态。 2、P0口上拉电阻的选择,应遵循基本的电路设计原则,不能盲目套用,要看后级情况而定: 例如,后级驱动的是1只NPN三极管,这个三极管的放大倍数(β)=100倍,三极管的负载电流(Ic)要求100mA,当电源为5V时: a、三极管的Ib=Ic/β=1mA; b、上拉电阻大约=R=5V/Ib=5kΩ; c、为了使三极管注入Ib后就迅速进入导通(开)状态,R应再小一些,如4k3; 3、由上面计算可见,三极管的
[单片机]
51单片机开发环境搭建方法
前言 上至航天,下至儿童玩具,凡事沾一点智能的东西,都离不开单片机的身影......,本文开始,我们学习单片机的相关知识,我们采用的是由普中科技开发的A7开发板,该开发板搭载了STC89C52或STC89C516两块芯片,这款单片机属于8051系列和STC8系列的单片机,51单片机作为入门级单片机不仅在教学实验中应用广泛,在实际项目中应用亦是十分广泛。 一、基础知识 1.什么是单片机? 单片机是一个单片微型计算机,由中央处理器CPU、数据存储器RAM、程序存储器ROM、输入/输出设备(键盘、显示屏等)等集成到一块芯片上组成。 2.单片机能做什么? 前言中开篇便比较好的阐释了单片机的功能,凡是沾点智能的影子的东西,都离不开单片机
[单片机]
51<font color='red'>单片机</font>开发环境搭建方法
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved