关于bcd码和十六进制数的区别
2个回答
展开全部
关于BCD码(以2进制表示10进制,但是在单片机中还是以16进制形式存储)和hex码转换的原因
HEX转换为BCD码的原因是:因为16进制字面的值表示的是10进制,这样表示是因为要方便我们查看。
例如串口发送21年时发送的是 0x21 ;但是单片机中进行加减乘除运算是以10进制进行计算的,所以要换算成实际的值进行计算。
如果不转换,则0x21= 33(10进制)进行计算显然不能得到我们想要的结果。
例如0x21 转化为21(10进制)=0x15(单片机内部存储形式)再进行计算,计算的结果就是正确的;
BCD码转换成16进制,便于我们查看
例如我们在存储器中存储的21年,21=0x15 如果我们直接输出年为0x15 不易看出是哪一年;
如果我们将0x15=21(十进制)转化为0x21 直接发送出来我们就很容易看出是21年
以此得出BCD转hex是为了串口发送数据时便于人去直观的去获得数据,不用再进行转换;
HEX转换为BCD码是为了正确计算,因为发进来的HEX码只是字面上的数值,并不是实际的数值,我们需要根据字面上的数值,得出实际的数值,这样才能正确的进行计算。
上海巴鲁图工程机械科技有限公司_
2022-05-15 广告
2022-05-15 广告
增量编码器一般输出信号是两路正交脉冲信号和一路参考信号,之所以叫增量是因为它的位置信号是通过对脉冲计数累加得到,依靠计数设备的内部记忆来记住位置,并且同每圈输出的参考信号来清除累计误差. 缺点就是断电后,需要重新寻找初始位置. 例如打印机扫...
点击进入详情页
本回答由上海巴鲁图工程机械科技有限公司_提供
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询