strncmp()的陷进

最近在做一个报文通信的事情,需要对报文的帧数据进行比较,帧头有固定的格式,比如:“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

 

 OK!

 

你可能感兴趣的:(tr)