这里比如你写一个网站,对照自己的用户和密码进行对比
strcmp(arr1,arr2)
常量
所以不能这样对比
而是
对比方式
如果要比较两个字符串的内容
比较逻辑 一一对应的比较
四种情况 这里比较的是内容
使用逻辑
上面的小于 返回值是-1
这里比较的对应ASCII码值的大小 遇见不一样的直接跳出循环 遇见一样但继续 一个一个进行对比 对比完进行下一个
返回数值逻辑 vs这里是-1 1 0 进行判断的 不一定一定是-1 1
使用的代码实现
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<assert.h>
#include<string.h>
int main()
{
char arr1[] = "sadaasd";
char arr2[] = "sadaasd";
char arr3[] = "sadasd ";
char arr4[] = "sadasde";
int ret1 = strcmp(arr1, arr2);//这里需要说明一下 是一个一个对应 什么意思呢就是 ss 对照 aa dd aa。。。所以返回0
int ret2 = strcmp(arr1, arr3);//ss aa dd aa as这里是a的ASCII码值比s小 所以返回-1 此时不进行下面的循环
int ret3 = strcmp(arr4, arr3);
//这里的逻辑对比是一一对比,如果 前面的字符大 此时也就返回1 小的情况下 也就返回-1 相等的情况下 也就是整个字符串相等 返回0
printf("%d\n%d\n%d\n\n", ret1, ret2, ret3);
printf("%d\n%d\n%d\n\n", ret1, ret2, ret3);
}
`strcmp` 是一个在 C 语言中常用的字符串比较函数,它的作用是比较两个字符串的内容是否相同。`strcmp` 函数的定义通常在 `<string.h>` 头文件中,其原型如下:
int strcmp(const char *str1, const char *str2);
`strcmp` 函数按照 ASCII 码的值逐个字符比较两个字符串。它的比较方式如下:
1. 从第一个字符开始比较,如果两个字符串的对应字符的 ASCII 码值相同,则继续比较下一个字符。
2. 如果两个字符串的对应字符的 ASCII 码值不同,`strcmp` 函数返回两个 ASCII 码值之间的差值的符号位,即如果第一个不同字符的 ASCII 码值在字符串1中大于字符串2中的对应字符,则返回正值;如果小于,则返回负值;如果相等,则继续比较下一个字符。
3. 如果在某个字符上比较结果不同,则函数停止比较并返回结果,不会等到字符串结束。
4. 如果两个字符串完全相同,`strcmp` 函数返回 `0`。
这里有一些例子来说明 `strcmp` 的比较方式:
// 比较 "hello" 和 "hello"
strcmp("hello", "hello") → 返回 0
// 比较 "hello" 和 "world"
strcmp("hello", "world") → 返回负值
// 比较 "hello" 和 "Hello" (注意大小写)
strcmp("hello", "Hello") → 返回负值
// 比较 "hello" 和 "hell" (较短的字符串)
strcmp("hello", "hell") → 返回正值
需要注意的是,`strcmp` 函数对比较的字符串大小写敏感。如果你需要进行不区分大小写的比较,可以使用 `strcasecmp` 函数(在 `<string.h>` 中定义)或者在 `strcmp` 函数中自己转换字符到小写或大写进行比较。
在使用 `strcmp` 函数时,应该注意比较的两个字符串都是以 `\0`(空字符)结尾的,因为如果两个字符串前缀相同,只有比较到字符串末尾或者发现一个字符不同时,`strcmp` 才会返回不同的结果。
这里加上const进行限制 防止进行修改
函数实现的逻辑 等于就继续 不等于就直接返回
在相等逻辑里面 进行判断 也就是同时遇见最后一个字符0 跳出循环
不给予准确数值 返回就可以
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<assert.h>
#include<string.h>
//这里采取的是两个模拟函数 也就是两个版本
int MY_strcmp(char* arr1, char* arr2)
{
while (*arr1 == *arr2)这里代码循环的条件就是只要相等就继续++ 然后遇见最后一个字符'\0'自然会跳出循环
{
if (*arr1 == '\0')//遇见'\0'说明已经遇到最后一个字符了 也就可以跳出循环
return 0;
*arr1++; *arr2++;
}
return *arr1 - *arr2;//其他情况下 直接可以返回指针的差值不一定是非得是1 =1 0 这样的数值 因为每个编译器的返回数值是不一样的 我这里是vs的编译器
}
int my_strcmp(char* arr1, char* arr2)
{
while (*arr1 == *arr2)//这里不能while(*arr1++==*arr2++)因为 这里是先++后等于 也就是 第一个元素和第二个元素的对比 所以不能这样的
{
if (*arr1 == '\0')//遇见'\0'说明已经遇到最后一个字符了 也就可以跳出循环
{
return 0;
}
*arr1++;//这里相等就继续++
*arr2++;//同理
}
if (*arr1 > *arr2)//这里是按照*arr1也就是元素的ASCII码值进行对比的 如果大于 就返回1 小于就返回-1 不需要判断0 因为相等会继续循环
{
return 1;
}
else
{
return -1;
}
}
int main()
{
char arr1[] = "sadaasd";
char arr2[] = "sadaasd";
char arr3[] = "sadasd ";
char arr4[] = "sadasde";
int ret1 = strcmp(arr1, arr2);//这里需要说明一下 是一个一个对应 什么意思呢就是 ss 对照 aa dd aa。。。所以返回0
int ret2 = strcmp(arr1, arr3);//ss aa dd aa as这里是a的ASCII码值比s小 所以返回-1 此时不进行下面的循环
int ret3 = strcmp(arr4, arr3);
//这里的逻辑对比是一一对比,如果 前面的字符大 此时也就返回1 小的情况下 也就返回-1 相等的情况下 也就是整个字符串相等 返回0
printf("%d\n%d\n%d\n\n", ret1, ret2, ret3);
int ret4 = my_strcmp(arr1, arr2);
int ret5 = my_strcmp(arr1, arr3);
int ret6 = my_strcmp(arr4, arr3);
printf("%d\n%d\n%d\n\n", ret4, ret5, ret6);
//这里大家可以自己看看
int ret7 = MY_strcmp(arr1, arr2);
int ret8 = MY_strcmp(arr1, arr3);
int ret9 = MY_strcmp(arr4, arr3);
printf("%d\n%d\n%d", ret7, ret8, ret9);
}