【期末不挂科-考前速过系列P4】单片机[接口与总线]——经典例题盘点(带图解析)(第四章:32题搞定基本指令例题))
2024-01-08 05:59:50
前言
大家好吖,欢迎来到 YY 滴单片机系列 ,热烈欢迎! 本章主要内容面向接触过单片机的老铁
主要内容含:
欢迎订阅 YY滴C++专栏!更多干货持续更新!以下是传送门!
一.算术运算类指令
- ADD是什么指令?D
- A.减法指令
- B.乘法指令
- C.除法指令
- D.不带进位位的加法指令
解析:如下图中所示,ADD不带进位位;ADDC带进位位;
注意:进位规则如下图所示:低字节相加用ADD,高字节相加用ADDC
- SUBB是什么指令?C
- A.减法指令
- B.乘法指令
- C.带借位的减法指令
- D.不带进位的加法指令
解析:减法指令一定带借位,减法(subtraction)
- DIV是什么指令?C
- A.减法指令
- B.乘法指令
- C.除法指令
- D.不带进位的加法指令
解析:顾名思义,division
- 执行DIV AB之后,B中存放的是什么?B
- A.商
- B.余数
- C.0
- D.1
- 执行DIV AB之后,A中存放的是什么?A
- A.商
- B.余数
- C.0
- D.1
解析:单片机中的除法规则如下图所示:按顺序记忆,从左至右,商先出来放A,余数后出放B
- MUL是什么指令?B
- A.减法指令
- B.乘法指令
- C.除法指令
- D.加法指令
解析:顾名思义,multiplication
- 执行MUL AB之后,A中存放的是运算结果数的什么?
- A.高8位
- B.低8位
- C.0
- D.1
- 执行MUL AB之后,B中存放的是运算结果数的什么?
- A.高8位
- B.低8位
- C.0
- D.1
解析:如下图所示:我们这样记忆,从低到高,低先出低放到A中,高后出放到B中;
对比记忆:除法中,商放在A中,余数放在B中;
- INC是什么指令?C
- A.加法指令
- B.减法指令
- C.加1指令
- D.减1指令
解析:顾名思义,增量 INC-Incremect
- DEC是什么指令?
- A.加法指令
- B.减法指令
- C.加1指令
- D.减1指令
解析:顾名思义,减量 DNC-Decrement
- DA是什么指令?
- A.加法指令
- B.减法指令
- C.加1指令
- D.十进制调整指令
解析:如下所示,主要用于进行BCD码运算时,跟在ADD和ADDC指令后
二.逻辑运算类指令
- ANL是什么指令?A
- A.逻辑与
- B.逻辑或
- C.逻辑异或
- D.逻辑非
解析:ANL,顾名思义(and);注意:值会送入A中
例如:(PS:ORG 是汇编中的伪指令。ORG 0000H 表示后面紧跟的那条指令的地址是 0000H)
- ORL是什么指令?B
- A.逻辑与
- B.逻辑或
- C.逻辑异或
- D.逻辑非
解析:顾名思义(OR Logic)
- XRL是什么指令?C
- A.逻辑与
- B.逻辑或
- C.逻辑异或
- D.逻辑非
解析:顾名思义。XRL它的全称是“XOR Register with Memory or Immediate”
- CPL A是什么指令?A
- A.取反
- B.清0
- C.逻辑非
- D.逻辑与
解析:顾名思义(Converse Position Logical),直接寻址位取反,是一个逻辑运算指令
- CLR A 是什么指令?
- A.取反
- B.清0
- C.逻辑非
- D.逻辑与
解析:顾名思义,(clear)
- RL A 是什么指令?A
- A.左移
- B.右移
- C.带进位左移
- D.带进位右移
- RR A 是什么指令?B
- A.左移
- B.右移
- C.带进位左移
- D.带进位右移
- RRC A 是什么指令?D
- A.左移
- B.右移
- C.带进位左移
- D.带进位右移
解析:如图所示;对比记忆,RR右移,RL左移;
- 带C后,还要连上进位一起动RRC,RLC
- 将一个数用RL指令往左移位一次,等效于将这个数乘2;RR指令右移一位,等效于将这个数除以2吗?对
- 在很多程序中,对一个数乘2或除以2,我们一般不采用乘法指令,而是RL和RR指令吗?对
三.控制转移类指令(条件类/无条件类)
- LJMP 是什么指令?A
- A.长转移指令
- B.短转移指令
- C.相对转移指令
- D.比较转移指令
- AJMP是什么指令?C
- A.长转移指令
- B.短转移指令
- C.相对转移指令
- D.比较转移指令
- SJMP是什么指令?B
- A.长转移指令
- B.短转移指令
- C.相对转移指令
- D.比较转移指令
解析:带JMP结尾的都是【无条件转移类指令】,JMP英文全称:Jump
- AJMP英文全称:Absolute?Jump; SJMP英文全称:Short Jump ;LJMP英文全称:Long Jump
- JZ 是什么指令?B
- A.长转移指令
- B.条件转移指令
- C.相对转移指令
- D.比较转移指令
- JNZ是什么指令?B
- A.长转移指令
- B.条件转移指令
- C.相对转移指令
- D.比较转移指令
解析:
- JZ指令,为0跳转,不为0继续;JZ---->jump when has zero flag
- JNZ指令,不为0跳转,为0继续;JNZ---->jump when not has zero flag
- CJNE是什么指令?B
- A.长转移指令
- B.比较转移指令
- C.短转移指令
- D.相对转移指令
- DJNZ是什么指令?A
- A.循环转移指令
- B.长转移指令
- C.短转移指令
- D.相对转移指令
解析:
- CJNE,顾名思义Compare Jump Not Equal 比较不相等转移指令
- DJNZ,顾名思义Decrement and Jump if Not Zero",意思是当操作数的值减1后(即 decrement),如果结果不等于0,则跳转到指定的目标地址
- 小总结:
- LCALL 是什么指令?A
- A.长转移指令
- B.条件转移指令
- C.长调用指令
- D.比较转移指令
- ACALL 是什么指令?C
- A.长转移指令
- B.条件转移指令
- C.短调用指令
- D.比较转移指令
解析:
四.位操作类指令
- CLR是什么指令?A
- A.清0
- B.取反
- C.置1
- D.传送
解析:顾名思义clear
- SETB是什么指令?C
- A.清0
- B.取反
- C.置1
- D.传送
解析:顾名思义set bit
- CPL是什么指令?
- A.清0
- B.取反
- C.置1
- D.传送
解析:顾名思义Converse Position Logical
- JB bit,rel是指定的bit位中的值是1,则转移吗?是的
- JBC bit, rel 是指定的bit位中的值是1,则转移吗?错的,还要指定bit位清0
- JNB bit,rel是指定的bit位中的值是0,则转移?是的
解析:
- 顾名思义jump bit;加C,还要clear
文章来源:https://blog.csdn.net/YYDsis/article/details/135415797
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!