Ⅰ 单片机C语言中将二进制数转化为十进制的办法
按照如下步骤即可用C语言把二进制数转换成十进制数的程序:
1、首先在主函数中设置成函数Sum,另外定义了一个数组array[8],用于存放输入的八位二进制数。
Ⅱ 跪求高人指点!!单片机十进制运算
单片机有BCD码调整指令DA A。如R2=23,R1=45,R1+R2=68。
mov a,r1
add a,r2
da a
此时A=68
Ⅲ 怎样在单片机中写8进制数
十六进制改八进制方法:
将十六进制度转换为二进制,然后将二进制以3位为一个基准,转换为8进制。
举个例子给你: F3H=11110011 十六进制是4位为基准即: 1111 0011
那转换八进制 为 011 110 011 那8进制结果为 363.
八进制 363=3*8*8+6*8+3=243
十六进制 F3H=15*16+3=243
结果为一致。你可以如上方法换算。
你在单片机中下363 指令和 十六进制F3H 是一样的效果。
Ⅳ 单片机,进制转换问题
十六进制459C4000转成二进制是0100 0101 1001 1100 0100 0000 0000 0000最高位为符号位,0表示整数,1表示负数,因此这个是一个正数。然后往后数8个位,这8个位叫阶码,就是1 1011 110=十进制的139。139-127(这个127是固定的)=12。将阶码换成1.,然后就是1.001 1100 0100 0000 0000 0000。根据刚才的到的12,就是小数点右移12位,就是1001 1100 0100 0.000 0000 0000。小数点前面是整数部分,1001 1100 0100 0转十进制就是5000,然后小数部分为000 0000 0000转成十进制就是0。因此最终结果是5000了。
十六进制4616000转成二进制是0100 0110 0001 0110 0000 0000 0000 0000最高位为符号位,0表示整数,1表示负数,因此这个也是一个正数。然后往后数8个位,这8个位叫阶码,就是100 0110 0=十进制的140。140-127=13。将阶码换成1.,然后就是1.001 0110 0000 0000 0000 0000。根据刚才的到的13,就是小数点右移13位,就是1001 0110 0000 00.00 0000 0000。小数点前面是整数部分,1001 0110 0000 00转十进制就是9600,然后小数部分为00 0000 0000转成十进制就是0。因此最终结果是9600了。
这个就是计算器中浮点数的存储、转换的方式。
望采纳。。。。。。
Ⅳ 51单片机16进制编程
如果是ASCII码表内的符号值,那么ASCII值本身就可以认为是 16进制的(因为进制只是给人看的,单片机只有2进制,没有ASCII 和 Hex 之分),但如果是Hex值,经过ASCII发送后,需要接收解出数值,那么可以用这个函数:
uchar ASCII_ToHex(uchar ascii_data) //ASCII 转 Hex 函数
{
uchar hex_data=0; //定义 Hex变量存储转换结果
if(ascii_data>='0' && ascii_data<='9') hex_data=ascii_data-'0'; //若 转换内容为 字符'0-9',则转成对应数字0-9
else if(ascii_data>='a' && ascii_data<='f') hex_data=ascii_data-'a'+10; //若 转换内容为 字符'a-f',则转成数字10-15
else if(ascii_data>='A' && ascii_data<='F') hex_data=ascii_data-'A'+10; //若 转换内容为 字符'A-F',则转成数字10-15
return hex_data; //返回转换结果,非以上字符,不在Hex(0-F)范围内,默认0
}//
Ⅵ 51单片机用汇编把16进制转化为10进制,这个程序不是很懂,希望高手能详细解释下
这个程序是正确的。
程序循环了16次。
把
M_byte,L_byte,左移了16次,最高位,依次移进了Cy;
用
ADDC
指令,把
RW1,RW2,左移了16次,并把Cy,加入到了最低位。
ADDC
指令后面,是十进制调整指令,所以,RW1,RW2
中的内容就是BCD码。
Ⅶ 单片机原理及应用中的十进制数与二进制数原码、反码、补码详细解答
首先得说明的一点,原码、反码、补码都是有符号定点数的表示方法。是吧,没有符号而言就不会出现+0与-0了呀,呵呵。
原码就是这个数本身的二进制形式。
例如:0000001 就是+1 1000001 就是-1
首先要说明的是:正数的反码和补码都是和原码相同的;
还是再重申一下吧
〔1〕原码:这个数本身的二进制形式。 例如十进制的8的原玛就是01000,就是用二进制表示〔2〕反码:将二进制数按位取反,所得的新二进制数称为原二进制数的反码。
〔3〕补码:负数的补码是将其原码除符号位之外的各位求反之后在末位再加1。
正数没什么好讲的,就说说负数吧:负数的原码,依旧是一个数本身的二进制形式,也就是说十进制的-8的原码就是11000[注意,第一位1是符号'-'哦];反码呢,将二进制数按位取反,所得的新二进制数称为原二进制数的反码。取反操作指:原为1,变为0;原为0,变为1。(1变0; 0变1),这个简单理解吧。实际上,这样说不够准确,因为我们还要除掉符号位再这样取反。
看好了-8的原码:11000----->-8的反码就是原码除了符号位之后的其他位都按位取反10111
符号位
-8原码 1 1 0 0 0
-8反码 1 0 1 1 1
现在懂什么是原码和反码了吧,我已经尽力了,呵呵。好啦,该补码登场啦。
补码,简单地说就是反码末位〔最后一位〕+1
为什么要设立补码呢?
第一是为了能让计算机执行减法:
[a-b]补=a补+(-b)补
第二个原因是为了统一正0和负0
正零:00000000
负零:10000000
这两个数其实都是0,但他们的原码却有不同的表示。
但是他们的补码是一样的,都是00000000
特别注意,如果+1之后有进位的,要一直往前进位,包括符号位!(这和反码是不同的!)
[10000000]补
=[10000000]反+1
=11111111+1
=(1)00000000
=00000000(最高位溢出了,符号位变成了0)
我不知道朋友您看了上面的是否真的懂了,或许还不知道什么叫做”溢出”吧
所谓的溢出就是当我们要表示的数位不够表示了
我们的二进制的位数一般有个具体的范围:
例如一个字节就是8位,超过8位当然就溢出了
以8位为例子,看好啦
符号位
0 1 1 1 1 1 1 1 1
+ 0 1
------------------------------------
0 [1]0 0 0 0 0 0 0 0
[1]表示就是进位没地方放了,怎么说呢,好象在十进制中,我有99个盒子已经装了99对鞋子,当第 100双鞋子没地方放了一样,超出了盒子个数,这样就产生了所谓的溢出了
好,我们再回到上面反码的例子,(别忘记我们是在介绍反码了)
符号位
[ 1 0 0 0 0 0 0 0]补
=〔 1 0 0 0 0 0 0 0]反+1
= 1 1 1 1 1 1 1 1 ------看到反码的取反操作在其中哦,0都变成1
+ 1
----------------------------------
= 1 (1) 0 0 0 0 0 0 0
= 0 0 0 0 0 0 0 0(最高位溢出了,符号位变成了0)
看到符号位也参与了计算一样1+1就变成了0,至于进位的1就丢失了
从而变成了全0
现在我们再来看看,原码 +0 的补码就是:0000 0000〔原因是补码和原玛是一样的〕
原玛 -0 的补码就是:0000 0000
是不是一样了,这样就消除了二异性了,不要说有-0与+0之分了
不知道朋友您是否还会觉得有什么不妥呢????
也许你会问
10000000这个补码表示的哪个数的补码呢?
其实这是一个规定,这个数表示的是-128
所以n位补码能表示的范围是
-2^(n-1)到2^(n-1)-1
比n位原码能表示的数多一个
原码,反码,补码 都是指二进制的形式,所以十进制的对应码为二进制数,注意负数的符号位,二进制数的码制转换就按照我上面说的啦,看仔细,多想一想,捡几个数做做练习一下,你就会啦,关键是练习。
其实就是这样的,单片机中的也就是计算机中的码制转换,单片机也叫微机嘛,即微型计算机,呵呵