//strcpy的使用
#include
int main()
{
char arr1[] = "abcdef";
char arr2[10] = "qwertt";
char arr3[10] = "okl";
strcpy(arr2, arr1);
printf("arr2 = %s\n", arr2);
strcpy(arr2, arr3);
printf("arr1 = %s\narr2 = %s\narr3 = %s", arr1,arr2,arr3);
return 0;
}
• 注意strcpy需要包含的头文件是
• 源字符串必须以 '\0' 结束,会将源字符串中的 '\0' 拷贝到目标空间。
• 目标空间必须足够大,以确保能存放源字符串。
• 目标空间必须可修改。
•strcpy函数返回的是目标空间的起始地址
如下例,字符中的'\0'也会同样被赋值进目标空间。
#include
int main()
{
char arr1[] = "xxxxxxxxxx";
char arr2[] = "abc";
strcpy(arr1, arr2);
printf("%s", arr1);
return 0;
}
当源字符串空间大于目标空间时,使用strcpy函数会有怎样的结果?
系统会报错。
#include
#include
int main()
{
char arr1[] = "xxxxxxxxxx";
char arr2[] = "abc";
strcpy(arr2, arr1);
printf("%s", arr2);
return 0;
}
strcpy函数返回的是目标空间的起始地址
strcpy函数的返回类型的设置是为了实现链式访问
#include
#include
#include
char *my_strcpy(char* str1, const char* str2)
{
assert(str1 && str2);
while (*str2)
{
*str1 = *str2;
++str1;
++str2;
if (*str2 == '\0')
*str1 = *str2;
}
return str1;
}
int main()
{
char arr1[] = "abcdef";
char arr2[] = "qwert";
my_strcpy(arr1,arr2);
printf("%s", arr1);
return 0;
}
进行优化
#include
#include
#include
char* my_strcpy(char* str1, const char* str2)
{
assert(str1 && str2);
while (*str1++ = *str2++)
{
;
}
return str1;
}
int main()
{
char arr1[] = "abcdef";
char arr2[] = "qwert";
my_strcpy(arr1, arr2);
printf("%s", arr1);
return 0;
}
#include
#include
int main()
{
char arr1[20] = "abcdef";
char arr2[] = "poiuy";
strcat(arr1, arr2);
printf("arr1=%s\narr2=%s", arr1, arr2);
return 0;
}
#include
#include
char* my_strcat(char* dest, char* src)
{
assert(dest && src);
char* ret = dest;
while (*dest)//找目标字符串中的'\0'
{
dest++;
}
while (*dest++ = *src++)//附加字符串
{
;
}
return ret;
}
int main()
{
char arr1[20] = "asdfg";
char arr2[] = "mnbvc";
my_strcat(arr1, arr2);
printf("%s", arr1);
return 0;
}
#include
#include
char* my_strcat(char* dest, char* src)
{
assert(dest && src);
char* ret = dest;
while (*dest)//找目标字符串中的'\0'
{
dest++;
}
while (*dest++ = *src++)//附加字符串
{
;
}
return ret;
}
int main()
{
char arr[20] = "asdfg";
my_strcat(arr, arr);
printf("%s", arr);
return 0;
}
存在错误,自身附加自身的字符串时,字符串的'\0'很容易被覆盖。
#include
#include
int main()
{
char arr1[] = "asdfgh";
char arr2[] = "ascfgh";
char arr3[] = "asdfghj";
char arr4[] = "asdfghj";
int ret1 = strcmp(arr2, arr1);
int ret2 = strcmp(arr3, arr1);
int ret3 = strcmp(arr2, arr3);
int ret4 = strcmp(arr4, arr3);
printf("%d %d %d %d", ret1, ret2, ret3,ret4);
return 0;
}
#include
#include
int* my_strcmp(char* s1, const char* s2)
{
assert(s1 && s2);
while (*s1 == *s2)
{
if(*s1 == '\0')
return 0;
s1++;
s2++;
}
if (*s1 > *s2)
return 1;
else
return -1;
}
int main()
{
char arr1[] = "asdfgh";
char arr2[] = "asdfg";
int ret = my_strcmp(arr1, arr2);
printf("%d", ret);
return 0;
}