字符串函数(第一篇)
一、strlen (计算字符个数)
1、strlen 的使用
size_t strlen ( const char * str );
• 字符串以 ‘ \0 ’ 结尾,strlen 计算的是 ‘ \0 ’ 之前字符的个数(不包括 ‘ \0 ’)
• 参数指向的字符串必须要以 ’ \0 ’ 结束
• 注意函数的返回值为 size_t,是无符号的
• strlen 的使用需要包含头文件 <string.h>
代码:
int main()
{
char arr[20] = "hello bit.";
printf("%zd\n", strlen(arr));
return 0;
}
计算结果:
2、strlen 的模拟实现
指针遍历字符串,所指向的内容不是‘ \0 ’,str 则向后移动一位,直到遇见‘ \0 ’,计算 ‘ \0 ’之前字符的个数
代码:
size_t my_strlen(const char* str)
{
int count = 0;
assert(str != NULL);
while (*str != '\0')
{
count++;
str++;
}
return count;
}
int main()
{
char arr[20] = "hello bit.";
printf("%zd\n", my_strlen(arr));
return 0;
}
二、strcpy(字符串拷贝)
1、strcpy 的使用
char* strcpy(char * destination, const char * source );
• 源字符串必须以’ \0 ’ 结束
• 会将源字符串中的 ’ \0 ’ 拷贝到目标空间
• 目标空间必须足够大,以确保能存放源字符串
• 目标空间必须可修改
• strcpy 的使用需要包含头文件 <string.h>
代码:
int main()
{
char arr1[10] = "abcdef";
char arr2[20] = { 0 };
strcpy(arr2, arr1);
return 0;
}
结果:arr1 的内容被拷贝到了 arr2 中
2、strcpy 的模拟实现
将 arr1 中的内容拷贝到 arr2 中,最后返回 str2 的地址
代码:
写法一:
char* my_strcpy(char* dest,const char* src)
{
char* ret = dest;
assert(dest&& src);
while (*src != '\0')
{
*dest = *src;
src++;
dest++;
}
return ret;
}
int main()
{
char arr1[10] = "abcdef";
char arr2[20] = { 0 };
my_strcpy(arr2, arr1);
return 0;
}
写法二:
char* my_strcpy(char* dest,const char* src)
{
char* ret = dest;
assert(dest && src);
while (*dest++ = *src++)
{
;
}
return ret;
}
int main()
{
char arr1[10] = "abcdef";
char arr2[20] = { 0 };
my_strcpy(arr2, arr1);
return 0;
}
三、strcmp(字符串的比较)
1、strcmp 的使用
int strcmp ( const char * str1, const char * str2 );
• 第一个字符串大于第二个字符串,则返回大于0的数字
• 第一个字符串等于第二个字符串,则返回0
• 第一个字符串小于第二个字符串,则返回小于0的数字• 那么如何判断两个字符串?
比较两个字符串中对应位置上字符ASCII码值的大小• strcmp 的使用需要包含头文件 <string.h>
代码:
int main()
{
char arr1[] = "abcdef";
char arr2[] = "abcd";
int ret = strcmp(arr1, arr2);
printf("%d\n", ret);
return 0;
}
结果:arr1 > arr2 ,返回一个 >0 的值
2、strcmp 的模拟实现
对应的字符依次进行比较,如果相同,str1、str2 向后移动继续进行比较
代码:
写法一:
int my_strcmp(const char* str1,const char* str2)
{
assert(str1 && str2);
while (*str1 == *str2)
{
if (str1 == '\0')
{
return 0;
}
str1++;
str2++;
}
if (*str1 > *str2)
return 1;
else
return -1;
}
int main()
{
char arr1[] = "abcdef";
char arr2[] = "abcd";
int ret = my_strcmp(arr1, arr2);
printf("%d\n", ret);
return 0;
}
写法二:
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;
}
int main()
{
char arr1[] = "abcdef";
char arr2[] = "abcd";
int ret = my_strcmp(arr1, arr2);
printf("%d\n", ret);
return 0;
}
四、strcat(字符串拼接)
1、strcat 的使用
char * strcat ( char * destination, const char * source );
• 源字符串必须以’ \0 ’ 结束
• 目标字符串中也得有 ‘ \0 ’ ,否则没办法知道追加从哪里开始
• 目标空间必须有足够的大,能容纳下源字符串的内容
• 目标空间必须可修改
• strcat 的使用需要包含头文件 <string.h>
代码:
int main()
{
char arr1[20] = "hello ";
char arr2[] = "world";
strcat(arr1, arr2);
printf("%s\n", arr1);
return 0;
}
运行结果:arr2 中的内容被拼接到了 arr1 后面
2、strcat 的模拟实现
str1 向后依次遍历,直到遇到‘ \0 ’,将 str2 中的内容赋值给 str1,最后返回 str1 的地址
代码:
写法一:
char* my_strcat(char* str1,const char* str2)
{
char* ret = str1;
while (*str1 != '\0')
{
str1++;
}
while (*str2 != '\0')
{
*str1 = *str2;
str1++;
str2++;
}
return ret;
}
int main()
{
char arr1[20] = "hello ";
char arr2[] = "world";
my_strcat(arr1, arr2);
printf("%s\n", arr1);
return 0;
}
写法二:
char* my_strcat(char* str1, const char* str2)
{
char* ret = str1;
while (*str1)
{
str1++;
}
while (*str1++ = *str2++)
{
;
}
return ret;
}
int main()
{
char arr1[20] = "hello ";
char arr2[] = "world";
my_strcat(arr1, arr2);
printf("%s\n", arr1);
return 0;
}