char* strcpy(char * destination,const char * source );
1.源字符串必须以’\0’结束。
2.会将源字符串中的’\0’拷贝到目标空间。
3.目标空间必须足够大,以确保能存放源字符串。
4.目标空间必须可变。
5.学会模拟实现。
char arr[10] = {0};
char arr1[] = {'a','b','c'};
strcpy(arr,arr1); //错误,arr1字符串没有明确给出'\0',拷贝不知何时停止
char* str = "***********";
char* p = "hello world";
strcpy(str,p); //程序奔溃,因为str指向的是个常量字符串,不能被修改,要求目标空间必须可变
//正常实现,通过指针找到两个数组的同一个下标空间,然后拷贝
void my_strcpy(char *dest,char *src)
{
while (*src != '\0')
{
*dest = *src;
dest++;
src++;
}
*dest = *src; //最后是为了将源数组的'\0'拷贝到目标数组中
}
//优化
void my_strcpy(char *dest,char *src)
{
while (*src != '\0')
{
*dest++ = *src++;
}
*dest = *src;
}
//再优化
void my_strcpy(char *dest,char *src)
{
while (*dest++ = *src++) //当*src指向'\0'时,*dest被赋值后,整个表达式的值为'\0','\0'的ASCII码是0,退出循环
{
;
}
}
//加上断言assert,需引入头文件
void my_strcpy(char *dest,char *src)
{
assert(src != NULL); //条件为真,则没问题,条件为假,则报错,即src不能是NULL
assert(dest != NULL);
while (*dest++ = *src++)
{
;
}
}
strcat – 追加
char * strcat ( char * destination,const char * source );
从目标字符串的’\0’位置开始追加(包括’\0’),把源字符串的第一位覆盖到目标字符串’\0’的位置,接下来的依次追加,最后把源字符串的’\0’也追加进去,所以目标字符串要有’\0’
#include
char* my_strcat(char* dest, const char* src)
{
assert(dest && src);
char* start = dest;
//1.找到目标字符串的'\0'
while (*dest != '\0')
{
dest++;
}
//找到'\0'
//2.将源字符串逐一追加过去,包括'\0'
while (*src != '\0')
{
*dest = *src;
dest++;
src++;
}
*dest = *src; //追加'\0'
return start;
}
int main()
{
char str1[20] = "hello ";
char str2[] = "world";
printf("%s", my_strcat(str1, str2));
return 0;
}
进阶写法:
#include
char* my_strcat(char* dest, const char* src)
{
assert(dest && src);
char* start = dest;
//1.找到目标字符串的'\0'
while (*dest)
{
dest++;
}
//找到'\0'
//2.将源字符串逐一追加过去,包括'\0'
while (*dest++ = *src++)
{
;
}
return start;
}
int main()
{
char str1[20] = "hello ";
char str2[] = "world";
printf("%s", my_strcat(str1, str2));
return 0;
}
int strcmp ( const char * str1,const char * str2 );
标准规定︰
第一个字符串大于第二个字符串,则返回大于0的数字
第一个字符串等于第二个字符串,则返回0
第一个字符串小于第二个字符串,则返回小于0的数字
那么如何判断两个字符串?(比较对应字符的ASCII码值)
//1.普通写法
int my_strcmp(const char* str1, const char* str2)
{
while (*str1 == *str2)
{
if (*str1 == '\0')
{
return 0;
}
str1++;
str2++;
}
//*str1 != *str2
if (*str1 > *str2)
{
return 1;
}
else
{
return -1;
}
}
//2.进阶写法
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; //strcmp函数并没有规定比较结果返回值是1或-1,只是>0或<0都可以
}