最近在做一个报文通信的事情,需要对报文的帧数据进行比较,帧头有固定的格式,比如:“0xbf, 0x13, 0x97, 0x74 ....”,所以需要对接收到的数据进行帧头的比较,我想到了用strncmp()这个C库里的函数,对相关字节进行比对,于是我就如下写了:
#include <stdio.h> #include <string.h> int main() { char pushbuf[] = {0xbf, 0x13, 0x97,0x74, 0x00, 0x00, 0x40, 0x04, 0x00, 0x00, 0x00, 0xfc, 0xbf}; char buffer[] = {0xbf, 0x13, 0x97,0x74, 0x00, 0x77, 0x8, 0x0, 0x0, 0x0, 0x2b, 0x45, 0x6d, 0x38, 0xe9, 0xa}; if(strncmp(buffer, pushbuf, 14) == 0) { puts("竟然相等!!!\n"); } else { puts("应该这样才对\n"); } int i = 0; while(i<14) { printf("%2x---------%2x\n", pushbuf[i], buffer[i]); i++; } }
早在第6位就已经出现数据不等了,可是程序运行结果竟然是:
竟然相等!!!
经过长达1个小时的苦苦测试,发现这是strncmp中的一个陷进:
strncmp(char *str1, char *str2, int maxlen)函数是比较两个字符串前maxlen字符是否相等,如果等返回0,不等返回第一个不等字符的差(str1-str2)
但是,它一旦两个字符串在maxlen之前同时遇到了'\0'结束符,就结束比对了,而我的比较就是这么悲剧得相等了!
解决这个问题的办法是,用memcmp()函数 :
百度百科 写道
原型:int memcmp(const void *buf1, const void *buf2, unsigned int count);
用法:#include <string.h>或#include<memory.h>
功能:比较内存区域buf1和buf2的前count个字节。
说明:
当buf1<buf2时,返回值<0
当buf1=buf2时,返回值=0
当buf1>buf2时,返回值>0
用法:#include <string.h>或#include<memory.h>
功能:比较内存区域buf1和buf2的前count个字节。
说明:
当buf1<buf2时,返回值<0
当buf1=buf2时,返回值=0
当buf1>buf2时,返回值>0
OK!