单片机2

合集下载

单片机2

单片机2

图2-1 MCS-51的外部引脚
8
单片机原理与应用
EA /VPP:片外ROM访问允许信号输 出引脚/片内 EPROM编程电压输入引脚。 它的功能是: (1)当 EA =0时,允许单片机访问片外 ROM(不允许使用片内ROM)。所以, 对于无片内ROM的单片机(如8031)此 引脚应接地。 (2)当 EA =1时,允许单片机使用片内 ROM。对于具有片内ROM的单片机, 若该引脚为高电平,则CPU在访问片内 ROM时,当访问地址超过所配置容量的 最大值时,会自动转向访问片外ROM。 (3)在对片内EPROM进行编程时,用 于输入编程电压。
23
单片机原理与应用
7.其他主要部件
暂存寄存器TMP1、TMP2:用于暂时存放从 数据总线或ACC送来的操作数。 程序地址寄存器:用于存放当前指令的地址, 具体数据由程序计数器送入。 指令寄存器:用于存放当前正在执行的指令操 作码(指令的构成在下一章中介绍)。 指令译码器:用于对指令寄存器中的指令操作 码进行分析,并把译码结果送给定时与控制部件, 作为产生微操作控制信号的依据。 内部总线:包括地址总线、数据总线和控制总 线,分别用于传递与它们的名称相对应的信号, 内部总线是各部件间进行信息传递的公共通道, 信号传递过程由CPU全盘控制,分时操作,不会 发生冲突。
1.电源引脚
VCC:+5V电源。 Vss:地线。
图2-1 MCS-51的外部引脚
4
单片机原理与应用
2.外接晶振引脚
XTAL1、2: 用于连接晶体振荡器 和微调电容,以便与 单片机内部的振荡器 构成内部时钟电路, 当采用外部时钟时, 作为外部振荡信号的 输入端。
图2-1 MCS-51的外部引脚
20

单片机2修改

单片机2修改

8、已知程序执行前有A=01H,SP=42H,(41H)=FFH,(42H)=FFH。

下述程序执行后:POP DPHPOP DPLMOV DPTR,#3000HRL AMOV B,AMOVC A,@A+DPTRPUSH AMOV A,BINC AMOVC A,@A+DPTRPUSH ARETORG 3000HDB 10H,80H,30H,80H,50 H,80H请问:A= 80H ,SP= 42H,(41H)= 30H ,(42H)= 80H 。

9、在存储器扩展中,无论是线选法还是译码法,最终都是为了扩展芯片的片选端提供信号。

10、在MCS-51中,PC和DPTR都用于提供地址,但PC是为了访问程序存储器提供地址,而DPTR是为访问数据存储器提供地址。

11、16KB RAM存储器的首地址若为3000H,则末地址为 6FFF H。

二.选择题(每题2分,共16分)1、8051与8751的区别是:A、内部数据存储但也数目的不同B、内部程序存储器的类型不同C、内部数据存储器的类型不同D、内部的寄存器的数目不同2、判断以下有关PC和DPTR的结论是否正确?A、DPTR是可以访问的,而PC不能访问。

对B、它们都是8位的存储器错C、它们都有加1的功能。

错D、DPTR可以分为两个8位的寄存器使用,但PC不能。

对3、PC的值是A、当前正在执行指令的前一条指令的地址B、当前正在执行指令的下一条指令的地址C、当前正在执行指令的地址D、控制器中指令寄存器的地址4、判断下列说法是否正确A、 8031共有21个特殊功能寄存器,它们的位都是可以用软件设置的,因此,是可以进行位寻址的。

错B、内部RAM的位寻址区,只能供位寻址使用,而不能供字节寻址使用。

错C、程序计数器PC不能为用户编程时直接使用,因为它没有地址。

对5、下列说法错误的是:A、各中断发出的中断请求信号,都会标记在MCS -51系统的IE寄存器中。

B、各中断发出的中断请求信号,都会标记在MCS -51系统的TCON与SCON寄存器中。

单片机指令大全(二)2024

单片机指令大全(二)2024

单片机指令大全(二)引言概述:本文是关于单片机指令大全的第二部分。

在上一部分中,我们介绍了一些常用的单片机指令和其功能。

本文将继续介绍更多的单片机指令,包括数据传输、逻辑运算、算术运算、位操作以及状态寄存器等方面的指令。

这些指令将帮助您更好地理解和使用单片机。

1. 数据传输指令1.1. MOV指令:将一个数据从源操作数传送到目的操作数。

1.2. LDI指令:将一个立即数传送到一个寄存器。

1.3. LDS和STS指令:将数据从SRAM传送到寄存器或将寄存器的数据传送到SRAM。

1.4. IN和OUT指令:将数据从端口传送到寄存器或从寄存器传送到端口。

2. 逻辑运算指令2.1. AND、OR和XOR指令:进行逻辑与、逻辑或和逻辑异或运算。

2.2. NOT指令:对一个寄存器的数据进行逻辑非运算。

2.3. CLR指令:将一个寄存器的数据清零。

3. 算术运算指令3.1. ADD和SUB指令:对两个操作数进行加法或减法运算。

3.2. INC和DEC指令:对一个寄存器的数据进行加1或减1操作。

3.3. MUL和DIV指令:进行乘法和除法运算。

4. 位操作指令4.1. ANDI、ORI和XORI指令:对一个寄存器的数据进行与、或和异或运算。

4.2. SBI和CBI指令:设置或清除一个I/O端口的某个位。

4.3. SBIC和SBIS指令:跳转指令,根据指定的I/O端口位是否被设置或清除执行跳转操作。

5. 状态寄存器相关指令5.1. SEI和CLI指令:设置或清除全局中断。

5.2. SREG指令:用于保存和恢复状态寄存器的值。

5.3. IJMP和EIJMP指令:用于从程序中直接跳转到任意存储器位置。

总结:本文介绍了单片机指令大全的第二部分内容,包括数据传输、逻辑运算、算术运算、位操作以及状态寄存器等方面的指令。

这些指令的功能与用法将有助于您更好地理解和应用单片机。

通过熟练掌握这些指令,您将能够更加灵活地进行单片机程序的设计与开发。

单片机 (2)

单片机 (2)

单片机1. (一)选择题50道1.51单片机芯片是双列直插式封装的,有(C)个引脚 [单选题] *A、24B、30C、40(正确答案)D、502. 一个机器周期等于()个振荡周期。

[单选题] *A、2B、4C、8D、12(正确答案)3. 单片机中,程序状态字CY、OV、P分别为()。

[单选题] *A、进位、溢出、奇偶标志位B、溢出、进位、奇偶标志位C、进位、溢出、A累加器1的奇偶标志位(正确答案)D、奇偶标志位、进位、溢出位4. 在单片机应用系统中,LED数码管显示电路通常有()显示方式。

[单选题] *A、静态B、动态C、静态和动态(正确答案)D、查询5. 启动定时器0开始计数的指令是使TCON的() [单选题] *A、TF0位置1B、TR0位置1(正确答案)C、TR0位置0D、TR1位置06. 单片机中断允许寄存器中的定时器T1允许或禁止控制位是()。

[单选题] *A、ET0B、ET1(正确答案)C、EX0D、EX17. 在串行通信中,数据传输沿两个方向,但需要分时进行传输的是()传输模式。

[单选题] *A、单工B、半双工(正确答案)C、全双工8. 提高单片机的晶振频率,则机器周期() [单选题] *A、不变B、变长C、变短(正确答案)D、不定9. C51编译器中不支持的存储模式是() [单选题] *A、Xdata(正确答案)B、SmallC、CompactD、Large10. 以下不是构成单片机的部件() [单选题] *A、微处理器B、存储器C、I/O接口D、打印机(正确答案)11. 单片机中断允许寄存器中的串行中断允许或禁止控制位是()。

[单选题] *A、ET0B、ET1C、ES(正确答案)D、EA12. D/A转换器所使用的数字量位数越多,则它的转换精度() [单选题] *A、越高(正确答案)B、越低C、不变D、不定13. 共阴极数码管是将所有发光二极管的( )连接在一起,数码管的动态显示是利用发光二极管的(),让人感觉数码管是同时点亮。

2004单片机(PIC) 2 单片机工作方式

2004单片机(PIC) 2 单片机工作方式
单片机原理及应用
第二章 单片机结构和流水线指令工作方式
2.1 2.2 2.3 2.4 2.5 PIC单片机的哈佛结构及引脚说明 PIC单片机的哈佛结构及引脚说明 流水线指令结构 程序储存器 寄存器结构和寻址方式 CPU内部寄存器 CPU内部寄存器
2.1 PIC单片机的哈佛结构及引脚说明 PIC单片机的哈佛结构及引脚说明
程 序 存 储 器
14 13 8
CPU
8
2.2 流水线指令结构
周期 从地址N 从地址N中读 取第n 取第n条指令 周期 执行第n 执行第n条 指令
从地址N+1读取 从地址N+1读取 第n+1条指令
周期
周期
执行第N+1条 执行第N+1条 指令
从地址N+2 从地址N+2 读取第n 读取第n条指令
执行第n 执行第n+2条 指令
从地址N 从地址N+3读 பைடு நூலகம்第n 取第n+3条指令
2.3 程序存储器
• PIC16f87x 有1个13位宽的程序计数器PC, 13位宽的程序计数器PC,
其最大寻址范围为:2 其最大寻址范围为:213=8K;(8k×14) (8k× • 系统复位时,PC自动指向0x0000; 系统复位时,PC自动指向0x0000; ORG 0H • 程序结构:
MOVF 0,0
FSR间接寻址
STATUS
位助记符

Bit0 Bit1 Bit2 Bit3 Bit4 Bit5 Bit6
说明
进位/ 进位/借位标志 辅助进位/ 辅助进位/借位标志 零标志位 降耗标志位 超时标志位 RAM数据存储器体选位,用于直接寻址 RAM数据存储器体选位,用于直接寻址
RP0 0 0 1 1 RP1 0 1 0 1 说明 选中体0 选中体0 选中体1 选中体1 选中体2 选中体2 选中体3 选中体3

单片机课件2

单片机课件2

5.2 定时/计数器51机内置了二个16位的定时/计数器,分别称为T0、T1(T2只在52机以上才有)。

5.2.2 定时/计数功能概述其中,T2只有52以上机才有。

每个定时/计数器均由两个独立的8位寄存器构成,分为高8位(H )和低8位(L )。

他们可以通过CPU 对工作方式寄存器TMOD 设置为16位寄存器使用,最大计数值为FFFFH ;也可独立作为8位寄存器使用,最大计数值为FFH 。

2.工作方式寄存器TMOD (89H ,不可位寻址)TMOD 上、下半字节对称,分别对应T0、T1的工作状态。

以T0为例,各位的意义如下: C/T :此位为0,为定时模式,此位为1,为计数模式。

M1、M0:工作方式选择。

该2位可组成00、01、10、11四种数字组合,对应为工作方式0、1、2、3。

注意:T1没有工作方式3。

GA TE ——定时/计数器启动方式控制位。

3.控制字寄存器TCON (88H ,可位寻址)TF1:定时器1的溢出标志;TF0:定时器0的溢出标志。

CPU 响应定时/计数器中断,标志自动清零;若CPU 不响应此中断,则此标志需用软件清除。

TR0:定时器0运行控制位,靠软件置位或清除。

置位时,定时/计数器0接通工作,TR0=0,定时器0停止工作。

TR1:是关于定时器1的,含义与TR0类似。

TCON 的低四位与外部中断相关,待讨论。

4.定时/计数器T0、T1工作方式及内部结构(1)工作方式0(13位定时/计数器,M1M0=00H)(少用)当 C/T =0时,计数脉冲来自CPU 内部分频器,为定时,标准51计数脉冲频率是时钟信号的12分频(而STC 系列有“6时钟/机器周期”和“12时钟/机器周期”两种模式,计数脉冲是系统时钟信号的6或12分频),当 C/T =1时,计数脉冲来自T0或T1引脚,即处于计数方式。

D0D1D2D3D4D5D6D7M0M0M1M1C/T C/T GATE GATE T1方式字段T0方式字段图5-8 定时/计数器工作方式寄存器TMOD D0D1D2D3D4D5D6D7IT0TR0IE0TF0TF1IE1图5-9定时/计数器控制寄存器TCON TR1IT1(2)工作方式1 (16位定时/计数器,M1M0=01H) (常用)(3)方式2 (M1M0=10) (常用) 此方式下,TLx 作为可自动重装8位计数器,TLx 的溢出不仅置位TFx ,而且将THx 的内容装入TLx 。

单片机 实验2-外部中断程序设计-中断按键按下次数计数数码管显示-硬件和程序设计参考

单片机 实验2-外部中断程序设计-中断按键按下次数计数数码管显示-硬件和程序设计参考

硬件电路参考如下:程序参考如下:#pragma sfr#pragma interrupt INTP0 LED_INTP0 /* 定义使用INTP0中断,中断函数名LED_INTP0*/ #pragma di /*禁止使用中断功能声明*/#pragma ei /*允许使用中断功能声明*//*数码管编码数组*/unsigned char LED_light[10]={0x30,0x5B,0x4F,0x66,0x6D,0x7D,0x07,0x7F,0x6F,0x3F}; unsigned char j=0; /*按键次数变量*/void hdinit() /*硬件初始化*/{PM1=0; /*P1口输出数码管字型码,所以设置为输出*/PU1=0XFF; /*由于P1口直接驱动数码管显示,为增大驱动,设置为内部上拉*/PM12.0=0; /*P12.0口线要作为中断多功能,设置为输出和内部上拉 */PU12.0=1;PIF0=0; /*中断请求标志,没有中断请求*/PMK0=0; /*中断屏蔽标志,允许中断*/PPR0=1; /*中断优先级,低优先级*/EGP.0=1; /*与EGN组合,上升沿有效*/EGN.0=0;}void main (void){DI(); /*首先做准备,禁止中断*/IMS=0XCC;IXS=0X00;hdinit();EI(); /*准备完成,允许中断*/while(1){ /*啥也不干,就等待中断,仅是在这个实验中使用中断,实际不是这样/*}}__interrupt void LED_INTP0() /*中断函数*/{ P1= LED_light[j]; /*P1赋值,数码管显示相应数值*/j++; /*按键次数加一*/if(j==10) /*如果按键次数达到十次,按键计数归0*/{j=0;} }思考: 如果用两位数码管,从0—99循环计数又该怎样设计硬件和软件呢?。

单片机 第二章 80C51系列单片机内部结构与工作原理

单片机 第二章 80C51系列单片机内部结构与工作原理

2.2 80C51单片机内部基本结构及引脚功能
③检查单片机芯片的好坏,可用示波器查看ALE端
是否有脉冲信号输出。
④ALE端的负载能力为8个LS型TTL。 :对EPROM型单片机,如对87C51BH编程时 的编程脉冲输入端。 ⑵、 (29脚):程序存储允许输出端。片外程
序存储器的读选通信号,低电平有效。
2.2 80C51单片机内部基本结构及引脚功能
3、基本功能单元
功能: 满足单片机测控功能要求的基本计算机外 围电路,用来完善和扩大计算机的功能.
组成: 包括定时/计数器、中断系统、串行通信 接口等。 说明: (1)80C51有两个16位定时/计数器 (T0和T1)。 作用: 可以作为内部定时器或外部脉冲计数器使 用。作内部定时器时,是靠对时钟振荡器的12分频脉
2.1 2.2 2.3
2.4
2.5 2.6
2.7
2.8 2.9
80C51系列单片机简介 80C51单片机内部基本结构及引脚功能 80C51单片机CPU结构 80C51存储器结构 输入/输出(I/O)端口 单片机的工作过程 80C51的低功耗方式 本章小结 练习思考题
第二章
80C51系列单片机内部结构与工作原理
①CPU从外部ROM取指令时,在每个机器周期中两 次有效。但在访问片外RAM时,要少产生两次负脉冲信
2.2 80C51单片机内部基本结构及引脚功能
号。有效时,将外部ROM中的指令读到数据总线上。
②检查单片机系统上电后,CPU能否正常到 EPROM/ROM中读取指令码,可用示波器查看该端有无负 脉冲信号输出。 ③可驱动8个LS型TTL门电路。
⑶、 (31脚):内部/外部ROM地址选择信号/ 固化编程电压输入端。 :①为高电平,CPU访问ROM有两种情况: 当PC中的值小于0FFFH时,执行片内ROM指令; 当PC中的值超过0FFFH时,将自动转向执行片外 ROM指令。
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

转载:二进制编码--负数负数:原码就是原来的表示方法反码是除符号位(最高位)外取反补码=反码+1以前学习二进制编码时,老师讲了一堆堆的什么原码啊反码啊补码啊xxxx转换啊,还有负数的表示方式啊总是记不零清,终于从网上找到了一种比较好的讲解方式,保存再share一下,不过为了系统化讲解,又找来了一些编码的基础知识,如果只想看负数编码记忆法,请跳转到1.如果你不知道二进制怎么编码,请继续,否则请跳到21字节= 8位,所以它能表示的最大数当然是8位都是1(既然2进制的数只能是0或1,如果是我们常见的10进制,那就8位都为9,这样说,你该懂了?)1字节的二进制数中,最大的数:11111111。

这个数的大小是多少呢?让我们来把它转换为十进制数。

无论是什么进制,都是左边是高位,右边是低位。

10进制是我们非常习惯的计数方式,第一位代表有几个1(即几个100),第二位代表有几个10(即几个101),第三位代表有几个100(即有几个102)…,用小学课本上的说法就是:个位上的数表示几个1,十位上的数表示向个10,百位上的数表示几个100……同理可证,二进制数则是:第1位数表示几个1 (20),第2位数表示几个2(21),第3位数表示几个4(22),第4位数表示向个8(23)……以前我们知道1个字节有8位,现在通过计算,我们又得知:1个字节可以表达的最大的数是255,也就是说表示0~255这256个数。

那么两个字节(双字节数)呢?双字节共16位。

1111111111111111,这个数并不大,但长得有点眼晕,从现在起,我们要学会这样来表达二制数:1111 1111 1111 1111,即每4位隔一空格。

双字节数最大值为:1 * 215 + 1 *214 + 1* 213 + 1 * 212 + 1 * 211 + 1 * 210+ …… + 1 * 22 + 1 * 21 + 1* 20 = 65535很自然,我们可以想到,一种数据类型允许的最大值,和它的位数有关。

具体的计算方法方法是,如果它有n位,那么最大值就是:n位二进制数的最大值:1 * 2(n-1) + 1 * 2(n-2) + ... + 1 * 202、理解有符号数和无符号数负数在计算机中如何表示呢?这一点,你可能听过两种不同的回答。

一种是教科书,它会告诉你:计算机用“补码”表示负数。

可是有关“补码”的概念一说就得一节课,这一些我们需要在第6章中用一章的篇幅讲2进制的一切。

再者,用“补码”表示负数,其实一种公式,公式的作用在于告诉你,想得问题的答案,应该如何计算。

却并没有告诉你为什么用这个公式就可以和答案?-----我就是被这个弄混淆的>_<另一种是一些程序员告诉你的:用二进制数的最高位表示符号,最高位是0,表示正数,最高位是1,表示负数。

这种说法本身没错,可是如果没有下文,那么它就是错的。

至少它不能解释,为什么字符类型的-1用二进制表示是“1111 1111”(16进制为FF);而不是我们更能理解的“1000 0001”。

(为什么说后者更好理解呢?因为既然说最高位是1时表示负数,那1000 0001不是正好是-1吗?-----re!当初偶就是这么想的,so一直在脑中打架,越打越混淆=,=)。

让我们从头说起。

2.1、你自已决定是否需要有正负。

就像我们必须决定某个量使用整数还是实数,使用多大的范围数一样,我们必须自已决定某个量是否需要正负。

如果这个量不会有负值,那么我们可以定它为带正负的类型。

在计算机中,可以区分正负的类型,称为有符类型,无正负的类型(只有正值),称为无符类型。

数值类型分为整型或实型,其中整型又分为无符类型或有符类型,而实型则只有符类型。

字符类型也分为有符和无符类型。

比如有两个量,年龄和库存,我们可以定前者为无符的字符类型,后者定为有符的整数类型。

2、使用二制数中的最高位表示正负。

首先得知道最高位是哪一位?1个字节的类型,如字符类型,最高位是第7位,2个字节的数,最高位是第15位,4个字节的数,最高位是第31位。

不同长度的数值类型,其最高位也就不同,但总是最左边的那位(如下示意)。

字符类型固定是1个字节,所以最高位总是第7位。

(红色为最高位)单字节数:1111 1111双字节数:1111 1111 1111 1111四字节数:1111 1111 1111 1111 1111 1111 1111 1111当我们指定一个数量是无符号类型时,那么其最高位的1或0,和其它位一样,用来表示该数的大小。

当我们指定一个数量是有符号类型时,此时,最高数称为“符号位”。

为1时,表示该数为负值,为0时表示为正值。

3、无符号数和有符号数的范围区别。

无符号数中,所有的位都用于直接表示该值的大小。

有符号数中最高位用于表示正负,所以,当为正值时,该数的最大值就会变小。

我们举一个字节的数值对比:无符号数:1111 1111 值:255 1* 27 + 1* 26 + 1* 25 + 1* 24 + 1* 23 + 1* 22 + 1* 21 + 1* 20有符号数:0111 1111 值:127 1* 26 + 1* 25 + 1* 24 + 1* 23 + 1* 22 + 1* 21 + 1* 20同样是一个字节,无符号数的最大值是255,而有符号数的最大值是127。

原因是有符号数中的最高位被挪去表示符号了。

并且,我们知道,最高位的权值也是最高的(对于1字节数来说是2的7次方=128),所以仅仅少于一位,最大值一下子减半。

不过,有符号数的长处是它可以表示负数。

因此,虽然它的在最大值缩水了,却在负值的方向出现了伸展。

我们仍一个字节的数值对比:无符号数:0 ----------------- 255有符号数:-128 --------- 0 ---------- 127同样是一个字节,无符号的最小值是0 ,而有符号数的最小值是-128。

所以二者能表达的不同的数值的个数都一样是256个。

只不过前者表达的是0到255这256个数,后者表达的是-128到+127这256个数。

一个有符号的数据类型的最小值是如何计算出来的呢?有符号的数据类型的最大值的计算方法完全和无符号一样,只不过它少了一个最高位(见第3点)。

但在负值范围内,数值的计算方法不能直接使用1* 26 + 1* 25的公式进行转换。

在计算机中,负数除为最高位为1以外,还采用补码形式进行表达。

所以在计算其值前,需要对补码进行还原。

这里,先直观地看一眼补码的形式:以我们原有的数学经验,在10进制中:1 表示正1,而加上负号:-1 表示和1相对的负值。

那么,我们会很容易认为在2进制中(1个字节): 0000 0001 表示正1,则高位为1后:1000 0001应该表示-1。

然而,事实上计算机中的规定有些相反,请看下表:首先我们看到,从-1到-128,其二进制的最高位都是1(表中标为红色),正如我们前面的学。

然后我们有些奇怪地发现,1000 0000 并没有拿来表示-0;而1000 0001也不是拿来直观地表示-1。

事实上,-1 用1111 1111来表示。

怎么理解这个问题呢?先得问一句是-1大还是-128大?当然是-1 大。

-1是最大的负整数。

以此对应,计算机中无论是字符类型,或者是整数类型,也无论这个整数是几个字节。

它都用全1来表示-1。

比如一个字节的数值中:1111 1111表示-1,那么,1111 1111 - 1 是什么呢?和现实中的计算结果完全一致。

1111 1111 - 1 = 1111 1110,而1111 1110就是-2。

这样一直减下去,当减到只剩最高位用于表示符号的1以外,其它低位全为0时,就是最小的负值了,在一字节中,最小的负值是1000 0000,也就是-128。

--------小米批注:就是这部分蓝色的文字,让我终于能记清楚-1的编码方式了,汗=。

=我们以-1为例,来看看不同字节数的整数中,如何表达-1这个数:可能有同学这时会混了:为什么1111 1111 有时表示255,有时又表示-1?所以我再强调一下本节前面所说的第2点:你自已决定一个数是有符号还是无符号的。

写程序时,指定一个量是有符号的,那么当这个量的二进制各位上都是1时,它表示的数就是-1;相反,如果事选声明这个量是无符号的,此时它表示的就是该量允许的最大值,对于一个字节的数来说,最大值就是255。

ok 摘抄暂告段落,其实原文对于c的一些基础数据类型知识介绍的非常详细,8过太长了,摘到我需要的内容后就没全帖过来,如果有需要学习的同学,建议参见原文:)转自/7892477/1201309.aspx关键字:二进制编码,负数二进制,二进制1-6 什么叫机器数?计算机为什么要采用补码?2007-09-09 14:24:25大中小标签:教育杂谈在计算机内部,所有信息都是用二进制数串的形式表示的。

整数通常都有正负之分,计算机中的整数分为无符号的和带符号的。

无符号的整数用来表示0和正整数,带符号的证书可以表示所有的整数。

由于计算机中符号和数字一样,都必须用二进制数串来表示,因此,正负号也必须用0、1来表示。

通常我们用最高的有效位来表示数的符号(当用8位来表示一个整数时,第8位即为最高有效位,当用16位来表示一个整数时,第16位即为最高有效位。

)0表示正号、1表示负号,这种正负号数字化的机内表示形式就称为“机器数”,而相应的机器外部用正负号表示的数称为“真值”。

将一个真值表示成二进制字串的机器数的过程就称为编码。

无符号数没有原码、反码和补码一说。

只有带符号数才存在不同的编码方式。

带符号整数有原码、反码、补码等几种编码方式。

原码即直接将真值转换为其相应的二进制形式,而反码和补码是对原码进行某种转换编码方式。

正整数的原码、反码和补码都一样,负数的反码是对原码的除符号位外的其他位进行取反后的结果(取反即如果该位为0则变为1,而该位为1则变为0的操作)。

而补码是先求原码的反码,然后在反码的末尾位加1 后得到的结果,即补码是反码+1。

IBM-PC中带符号整数都采用补码形式表示。

(注意,只是带符号的整数采用补码存储表示的,浮点数另有其存储方式。

)采用补码的原因或好处如下。

采用补码运算具有如下两个特征:1)因为使用补码可以将符号位和其他位统一处理,同时,减法也可以按加法来处理,即如果是补码表示的数,不管是加减法都直接用加法运算即可实现。

2)两个用补码表示的数相加时,如果最高位(符号位)有进位,则进位被舍弃。

这样的运算有两个好处:1)使符号位能与有效值部分一起参加运算,从而简化运算规则。

从而可以简化运算器的结构,提高运算速度;(减法运算可以用加法运算表示出来。

)2)加法运算比减法运算更易于实现。

相关文档
最新文档