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!

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值