admin管理员组文章数量:1794759
strcmp函数详解看这一篇就够了
首先要明确strcmp的功能是:用来比较两个字符串
目录
函数介绍
ACSII表
与strncmp的区别
函数实现:
用法示例:
结果展示:
函数介绍函数原型:int strcmp(const char* str1, const char* str2)
头 文 件:#include <string.h> 返 回 值:str1 = str2 则返回0, str1 > str2 则返回大于0的值, str1 < str2 则返回小于0的值 说明: 判断两个字符串大小 1)ACSII码 2)长度 注:区分大小写比较的,如果希望不区分大小写进行字符串比较,可以使用stricmp函数
strcmp()函数首先将str1字符串的第一个字符的ACSII值减去str2第一个字符的ACSII值(自左向右逐个字符相比,直到出现不同的字符或遇'\\0'为止)
若差值为零则继续比较下去;若差值不为零,则返回差值。
特别注意:strcmp可用于比较两个字符串常量或比较数组和字符串常量,不能比较数字等其他形式的参数。
ACSII表 与strncmp的区别1、先比较一下两个函数传参的不同:
int My_strncmp(const char* str1, const char* str2, int num)
int My_strcmp(const char* str1, const char* str2)
strcmp与strncmp都是用来比较字符串的,区别在于能否比较指定长度字符串,故要多传一个长度参数,这也使得strncmp比strcmp更加精细。
函数实现: //以null结尾的字符串 const修饰防止字符串被修改,进行保护 int My_strcmp(const char* str1, const char* str2) { assert(NULL != str1); assert(NULL != str2);//防御性编程 while ( *(unsigned char*)str1 == *(unsigned char*)str2 ) { if( *(unsigned char*)str1 !='\\0') { return 0;//当*(unsigned char*)str1 ==*(unsigned char*)str2==‘\\0'时两个字符串完全相等 } str1++; //比较下个字符 str2++; } //*(unsigned char*)str1 与*(unsigned char*)str2的差值与返回值正负匹配 return *(unsigned char*)str1 - *(unsigned char*)str2; } 用法示例: #include <stdio.h> #include<string.h> #include <assert.h> //以null结尾的字符串 const修饰防止字符串被修改,进行保护 int My_strcmp(const char* str1, const char* str2) { assert(NULL != str1); assert(NULL != str2);//防御性编程 while (*(unsigned char*)str1 == *(unsigned char*)str2) { if (*(unsigned char*)str1 != '\\0') { return 0;//当*(unsigned char*)str1 ==*(unsigned char*)str2==‘\\0'时两个字符串完全相等 } str1++; //比较下个字符 str2++; } //*(unsigned char*)str1 与*(unsigned char*)str2的差值与返回值正负匹配 return *(unsigned char*)str1 - *(unsigned char*)str2; } int main() { char str1[] = "I LOVE YOU "; char str2[] = "SORRY"; //经过手算可发现I的ACSII=73,S的ACSII=83,应该返回-10 printf("%d\\n", My_strcmp(str1, str2)); return 0; } 结果展示:以上就是关于strcmp的解析啦。如果对你有帮助,记得点赞👍+关注哦! 我的主页还有其他文章,欢迎学习指点。 关注我,让我们一起学习,一起成长吧!
版权声明:本文标题:strcmp函数详解看这一篇就够了 内容由林淑君副主任自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.xiehuijuan.com/baike/1686493540a73710.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论