古老的代码,拿出来记录一下,代入QString类型的校验方式,才看到函数中的unsigned char RTU_crcdata[5000];根据传入的字符串str的大小来分配空间大小更兼容,懒得改了就这样吧,基本原理没问题就行
// CRC16--S MODBUS 算 法
uint16_t myCRC16(unsigned char *dat, unsigned int len)
{
uint16_t crc=0xffff;
uint8_t i;
while(len!=0)
{
crc^=*dat;
for(i=0;i<8;i++)
{
if((crc&0x0001)==0)
crc=crc>>1;
else
{
crc=crc>>1;
crc^=0xa001;
}
}
len-=1;
dat++;
}
return crc;
}
// 字符串形式的CRC16——modbus校验
QString crc16_QString(QString str)
{
unsigned char *RTU_data;
unsigned char RTU_crcdata[5000];
RTU_data=(unsigned char *)str.toLatin1().data();
for (int i=0;i<str.length();i++) {
if(48<=RTU_data[i]&&RTU_data[i]<=57){
RTU_data[i]-=48;
}else{
RTU_data[i]-=55;
}
}
for (int i=0;i<(str.length()/2);i++) {
if(i>=5000){
// myDebug()<<"数据溢出,计算错误!";break;
}
RTU_crcdata[i]=(RTU_data[2*i]*16)+RTU_data[2*i+1];
}
uint16_t rtu_crc=myCRC16(RTU_crcdata,(str.length()/2));
QString str_rtu_crc=QString::number (rtu_crc,16);
if(str_rtu_crc.length()<4)//没达到四位,用0补齐四位
{
str_rtu_crc = QString("%1").arg(str_rtu_crc, 4, QLatin1Char('0'));
}
return str_rtu_crc;
}