共2条
1/1 1 跳转至页
请教一下,十六进制与十进制转换的问题,希望大家给出个好办法

问
现在我把一个十六进制数0x096363分为三个字节转换为十进制送显示为99999同时把它给赋
值给t,显示完之后,进行一个运算t=t-100,得到的 t=99899,通过取整的办法得到整数位
再送显示
DispBuf[0]=cardmoney/10000;
DispBuf[1]=(cardmoney- DispBuf[0]*10000)/1000;
DispBuf[2]=(cardmoney- DispBuf[0]*10000-DispBuf[1]*1000)/100;
DispBuf[3]=(cardmoney- DispBuf[0]*10000-DispBuf[1]*1000-DispBuf[2]*100)/10;
DispBuf[4]=cardmoney%10;
同时将得到的数在按单个字节转换成十六进制送给机器
SendBuffer[13]=BCD2HEX(DispBuf[0]);
SendBuffer[14]=BCD2HEX((DispBuf[1]*10)+(DispBuf[2]));
SendBuffer[15]=BCD2HEX((DispBuf[3]*10)+(DispBuf[4]));
可是这样转换没有得到正确(推算该结果为0x95963)的结果
请高手指点一下,谢谢!
答 1: 给点程序你参考参考////////////////////////// LCD显示一个长整数 /////////////////////////////////////////////////
void printf(unsigned long int x)
{
signed char i;
unsigned char display_buffer[10];
for(i=9;i>=0;i--)
{
display_buffer[i]='0'+x%10;
x/=10;
}
for(i=0;i<9;i++)
{
if(display_buffer[i]!='0')break;
}
for(;i<10;i++)write_LCD_data(display_buffer[i]);
}
///////////////////////////////////////////////////////////////////////////////////////////////// 答 2: 倒着算简单得多//unsigned long cardmoney;
cardmoney = 0x096363;
//unsigned char SendBuffer[];
SendBuffer[13] = BCD2HEX(cardmoney >> 16);//BCD2HEX(0x09)=0x09
SendBuffer[14] = BCD2HEX(cardmoney >> 8); //BCD2HEX(0x63)=0x99
SendBuffer[15] = BCD2HEX(cardmoney); //BCD2HEX(0x63)=0x99
//unsigned char DispBuf[];
DispBuf[0] = SendBuffer[13]; //0x09
DispBuf[1] = SendBuffer[14] >> 4; //0x09
DispBuf[2] = SendBuffer[14] & 0x0f; //0x09
DispBuf[3] = SendBuffer[15] >> 4; //0x09
DispBuf[4] = SendBuffer[15] & 0x0f; //0x09
unsigned char BCD2HEX(unsigned char val)
{
return (((val / 10) << 4) + (val % 10));
}
值给t,显示完之后,进行一个运算t=t-100,得到的 t=99899,通过取整的办法得到整数位
再送显示
DispBuf[0]=cardmoney/10000;
DispBuf[1]=(cardmoney- DispBuf[0]*10000)/1000;
DispBuf[2]=(cardmoney- DispBuf[0]*10000-DispBuf[1]*1000)/100;
DispBuf[3]=(cardmoney- DispBuf[0]*10000-DispBuf[1]*1000-DispBuf[2]*100)/10;
DispBuf[4]=cardmoney%10;
同时将得到的数在按单个字节转换成十六进制送给机器
SendBuffer[13]=BCD2HEX(DispBuf[0]);
SendBuffer[14]=BCD2HEX((DispBuf[1]*10)+(DispBuf[2]));
SendBuffer[15]=BCD2HEX((DispBuf[3]*10)+(DispBuf[4]));
可是这样转换没有得到正确(推算该结果为0x95963)的结果
请高手指点一下,谢谢!
答 1: 给点程序你参考参考////////////////////////// LCD显示一个长整数 /////////////////////////////////////////////////
void printf(unsigned long int x)
{
signed char i;
unsigned char display_buffer[10];
for(i=9;i>=0;i--)
{
display_buffer[i]='0'+x%10;
x/=10;
}
for(i=0;i<9;i++)
{
if(display_buffer[i]!='0')break;
}
for(;i<10;i++)write_LCD_data(display_buffer[i]);
}
///////////////////////////////////////////////////////////////////////////////////////////////// 答 2: 倒着算简单得多//unsigned long cardmoney;
cardmoney = 0x096363;
//unsigned char SendBuffer[];
SendBuffer[13] = BCD2HEX(cardmoney >> 16);//BCD2HEX(0x09)=0x09
SendBuffer[14] = BCD2HEX(cardmoney >> 8); //BCD2HEX(0x63)=0x99
SendBuffer[15] = BCD2HEX(cardmoney); //BCD2HEX(0x63)=0x99
//unsigned char DispBuf[];
DispBuf[0] = SendBuffer[13]; //0x09
DispBuf[1] = SendBuffer[14] >> 4; //0x09
DispBuf[2] = SendBuffer[14] & 0x0f; //0x09
DispBuf[3] = SendBuffer[15] >> 4; //0x09
DispBuf[4] = SendBuffer[15] & 0x0f; //0x09
unsigned char BCD2HEX(unsigned char val)
{
return (((val / 10) << 4) + (val % 10));
}
共2条
1/1 1 跳转至页
回复
打赏帖 | |
---|---|
【STM32F769】AI之与本地deepseek对接被打赏50分 | |
Buck电路工作在CCM模式下电感电流的计算公式是什么?被打赏5分 | |
buck电路工作原理被打赏5分 | |
基于MSPM0L1306的MODBUS-RTU协议通讯实验被打赏100分 | |
我想要一部加热台+多合一调试工具被打赏18分 | |
每周了解几个硬件知识+485硬件知识分享被打赏10分 | |
【换取手持数字示波器】树莓派PICO调试器官方固件本地化部署实践被打赏24分 | |
【换取手持数字示波器】分享一个KEIL无法识别CMSIS-DAP调试器的解决办法被打赏20分 | |
【换取手持数字示波器】分享一个自制的ArduinoNano扩展板底板被打赏23分 | |
【换取手持示波器】树莓派PICOW网页烟花被打赏18分 |