单片机中怎样看地址是8位还是16位
例如#1234怎样看他是16位的????还有一个问题,DPTR是一个16位的特殊功能寄存器,它里面存储的位数是不是必须等于16位,还是小于等于它就可以啊?????...
例如#1234怎样看他是16位的????
还有一个问题,DPTR是一个16位的特殊功能寄存器,它里面存储的位数是不是必须等于16位,还是小于等于它就可以 啊????? 展开
还有一个问题,DPTR是一个16位的特殊功能寄存器,它里面存储的位数是不是必须等于16位,还是小于等于它就可以 啊????? 展开
5个回答
推荐于2016-05-18
展开全部
查看单片机地址是8位还是16位,只能用指令实现:
16位的单片机地址,向DPTR里边传送数据,不论NUM有多小,肯定是16位的数据传送,如下:
MOV DPTR, #NUM
8位的单片机地址,向DPTR里边传送数据,则肯定是8位的数据传送,如下:
MOV DPH, #NUM,
或:
MOV DPL, #NUM,
对大于8位而小于等于16位的数据进行加法运算,16位处理器可以一次完成,8位的则要拆分成多步来运算,即使二者的运算速度相同,处理16位数据8位处理器也会比16位处理器慢多了。
8位单片机,典型的是51系列的,再高级点用AVR、pic的,功能方面,似乎都不会很复杂,一般可能是控制类的多一下。一般不跑嵌入式OS。
16位的单片机,16位的单片机比较尴尬,高不成低不就,要求低一点,8位MCU就够,高级点不如用32位MCU。
32位的,就高级点了,一般能跑嵌入式OS,例如ucos2,ucos3,uclinux等等,能做更多复杂的功能。用OS和不用OS的话,编程的思路差异比较大。功能一般有面向控制的,也有简单消费类电子的。
16位的单片机地址,向DPTR里边传送数据,不论NUM有多小,肯定是16位的数据传送,如下:
MOV DPTR, #NUM
8位的单片机地址,向DPTR里边传送数据,则肯定是8位的数据传送,如下:
MOV DPH, #NUM,
或:
MOV DPL, #NUM,
对大于8位而小于等于16位的数据进行加法运算,16位处理器可以一次完成,8位的则要拆分成多步来运算,即使二者的运算速度相同,处理16位数据8位处理器也会比16位处理器慢多了。
8位单片机,典型的是51系列的,再高级点用AVR、pic的,功能方面,似乎都不会很复杂,一般可能是控制类的多一下。一般不跑嵌入式OS。
16位的单片机,16位的单片机比较尴尬,高不成低不就,要求低一点,8位MCU就够,高级点不如用32位MCU。
32位的,就高级点了,一般能跑嵌入式OS,例如ucos2,ucos3,uclinux等等,能做更多复杂的功能。用OS和不用OS的话,编程的思路差异比较大。功能一般有面向控制的,也有简单消费类电子的。
展开全部
#1234怎样看他是16位的????
---------
变换成二进制数,即可看出。
如#1234,变换后:
0001 0010 0011 0100
显然是16位的。
但是,有些较小的数字,变换后用8位二进制数即可表达,可是在指令里面,仍然要写成16位数。 这时要看指令的格式要求。
------------------------------
用指令:
MOV DPTR, #NUM
向DPTR里边传送数据,不论NUM有多小,肯定是16位的数据传送。
而用指令:
MOV DPH, #NUM,
或:
MOV DPL, #NUM,
向DPTR里边传送数据,则肯定是8位的数据传送。
---------
变换成二进制数,即可看出。
如#1234,变换后:
0001 0010 0011 0100
显然是16位的。
但是,有些较小的数字,变换后用8位二进制数即可表达,可是在指令里面,仍然要写成16位数。 这时要看指令的格式要求。
------------------------------
用指令:
MOV DPTR, #NUM
向DPTR里边传送数据,不论NUM有多小,肯定是16位的数据传送。
而用指令:
MOV DPH, #NUM,
或:
MOV DPL, #NUM,
向DPTR里边传送数据,则肯定是8位的数据传送。
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
这个在程序里看还真不好说,不同的编译器的做法有些不同。
在keil中,0x12表示十六进制, 12,表示十进制,12H 12D这种写法刚试了一下好像不行。
在pic编译器MPLAB中,有条这样的指令:R=DEC,表示十进制,无特别指明,12就示10进制。。。R=。。。,12就表示16进制。
最有效的方法还是看其它反汇编代码吧,如,你定义一个变化a=12,用WATCH看ram或flash的数据,这里的数据是16进制的。
在keil中,0x12表示十六进制, 12,表示十进制,12H 12D这种写法刚试了一下好像不行。
在pic编译器MPLAB中,有条这样的指令:R=DEC,表示十进制,无特别指明,12就示10进制。。。R=。。。,12就表示16进制。
最有效的方法还是看其它反汇编代码吧,如,你定义一个变化a=12,用WATCH看ram或flash的数据,这里的数据是16进制的。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
在汇编里是十进制的立即数,也就是4位的.
例如
64H 就是8位的。H代表16进制的。(汇编里)
例如
64H 就是8位的。H代表16进制的。(汇编里)
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
#1234是立即数,表示十进制数。一个BYTE最大无符号值是255,这已经超过了。所以只能用2个BYTE存储
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询