strcmp和strncmp
Posted zsQgqdsd1002
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了strcmp和strncmp相关的知识,希望对你有一定的参考价值。
strcmp
和之前一样我们先来看看strcmp在msdn中的定义:
The strcmp function compares string1 and string2 lexicographically and returns a value indicating their relationship.
strcmp函数按字典顺序比较string1和string2,并返回一个表示它们之间关系的值。
这里有这么几点需要注意:
1.strcmp函数对字符串比较的实质是比较双方的ASCII码
2.strcmp在比较时遇到第一个不同的字符进行比较后就不会再继续判断了
3.若返回值为0代表两字符串相等,> 0代表前大于后,< 0代表后大于前
知道了这些,我们就可以开始自己实现一下strcmp函数了:
int Mystrcmp(const char* str1, const char* str2)
{
assert(str1 && str2);
int tmp = 0;
if (*str1 == '\\0')
{
tmp = 0;
}
while (*str1 == *str2)
{
str1++;
str2++;
if (*str1 > * str2)
{
tmp = 1;
}
else
{
tmp = -1;
}
}
return tmp;
}
int main()
{
const char* str1 = "abcdefg";
const char* str2 = "abcdfaf";
int ret = Mystrcmp(str1, str2);
printf("%d", ret);
return 0;
}
我们来看一下程序的输出结果:
非常的完美,而且我们发现比较完第一个之后就不会在比较了
strncmp
我们来看一下strncmp在msdn中的定义:
The strncmp function lexicographically compares, at most, the first count characters in string1 and string2 and returns a value indicating the relationship between the substrings.
strncmp函数按字典顺序最多比较string1和string2中的第一个count字符,并返回一个指示子字符串之间关系的值。
我们看定义与strncmp与前面的strcmp没有任何的区别,但是我们根据经验可以知道,strncmp肯定也是比较前n个字符的大小,我们现在来试着实现一下:
int Mystrncmp(const char* str1, const char* str2, int n)
{
assert(str1 && str2);
int tmp = 0;
if (*str1 == '\\0')
{
tmp = 0;
}
while (n != 0)
{
if (*str1 > * str2)
{
tmp = 1;
}
else if(*str1 == *str2)
{
tmp = 0;
}
else
{
tmp = -1;
}
str1++;
str2++;
n--;
}
return tmp;
}
int main()
{
const char* str1 = "abcdefg";
const char* str2 = "abcdfaf";
int n = 0;
scanf("%d", &n);
int ret = Mystrncmp(str1, str2, n);
printf("%d", ret);
return 0;
}
我们来试着输入不同的n来看看代码是否正确:
我们可以看到,非常的完美,输出的结果和n有着直接的关系
以上就是我今天想分享给大家的内容,如果有错误的或者可以改进的地方,欢迎大佬联系我。
以上是关于strcmp和strncmp的主要内容,如果未能解决你的问题,请参考以下文章
字符串函数---strcmp()与strncmp()详解及实现