前言:
本博客共分为strcmp函数的介绍和模拟实现两部分
strcmp函数的介绍及其应用:
- 专门用于比较两个字符串对应位置上字符的大小,而非长度
- strcmp的头文件是:#include <string,h>
- 提示:每段代码的注释都具有详细解释功能
strcmp的应用:
#include <stdio.h>
#include <string.h>//strcmp的头文件
int main()
{
char arr1[] = "abcdef";
char arr2[] = "abd";
int ret = strcmp(arr1, arr2);
printf("%d\n", ret);//-1---小于0的数
//arr1[]和arr2[]相对应位置进行比较
//前两个元素都一样“ab
//第三个:arr1是c;arr2是d;
//显然c<d
//于是前一个数组小于第二个数组
//于是乎
//返回小于0的数
return 0;
}
当 arr1>arr2---return 大于0的数
当 arr1<arr2---return 小于0的数
当 arr1=arr2---return 0
strcmp的模拟实现:
strcmp函数的设计:int strcmp(const char * str1,const char * str2);
思路:
格式:实现既然是模拟实现,则模拟的函数的格式一定要和原来的够像,最好一模一样。
返回值:strcmp函数是比较两个字符串大小的,前者比后者大,返回正数;后者比前者大,返回负数;二者一样大,返回0,所以设计的时候也要注意这点。
比较:strcmp函数是把两个字符串里的字符一个一个拿出来比较的,解引用可以实现得到地址指向的内容,加加循环可以实现地址不停后移,以达到后面逐个比较的目的。最后通过if语句判断比较,即可。
#include <stdio.h>
#include <assert.h>//assert头文件
int my_strcmp(const char* str1, const char* str2)
{
assert(str1 && str2);
while (*str1 == *str2)
{
if (*str1 == '\0')
{
return;
}
str1++;
str2++;
}
if (*str1 > *str2)
return 1;
else
return -1;
}
int main()
{
char arr1[] = "abcdef";
char arr2[] = "abd";
int ret = my_strcmp(arr1, arr2);
printf("%d\n", ret);
return 0;
}
优化版:
#include <stdio.h>
#include <assert.h>//assert头文件
int my_strcmp(const char* str1, const char* str2)
{
assert(str1 && str2);
while (*str1 == *str2)
{
if (*str1 == '\0')
{
return 0;
}
str1++;
str2++;
}
return *str1 - *str2;
//直接解引用(ASCII码值相减)然后再相减,
//若前者大返回值就大于零,反之则小于0或等于0
}
int main()
{
char arr1[] = "abcdef";
char arr2[] = "abd";
int ret = my_strcmp(arr1, arr2);
printf("%d\n", ret);
return 0;
}