首页 > 编程知识 正文

excel单元格加字符串,单元格前后有空字符串

时间:2023-05-06 05:29:23 阅读:206682 作者:3816

    最近做项目,遇到字符串格%02x式化输出出现FFFFFF现象,偶尔出现,大部分时间是好的,网上查阅资料,发现解决办法:


    C89标准规定,short和char会被自动提升为int(整形化,类似地,float也会自动提升为double),这样做是为了便于编译器进行优化,使变量的长度尽可能一样,尽可能提升所产生代码的效率。data[i]的值当它是正数的时候也同样进行了符号扩展的,只不过正数是前面加0,用%02x打印的时候那些0被忽略;而补码表示的负数的符号扩展却是前面加1,用%02x打印的时候那些1不能被忽略,因此才按照本来的长度输出来。如没有添加unsigned,则当data[i]>0x7F时(如0X80),格式转换为FFFFFF80!


    故计算8位异或校验函数调整如下:

unsigned char calc_crc(const char *buff, int buff_sz)
{
int chsum = 0, it;
for(it = 0; it < buff_sz; ++it)
chsum ^= (int)buff[it];
return (unsigned char)(chsum & 0xFF);
}


参考博客地址:http://blog.csdn.net/avatar1912/article/details/7219345


版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。