admin 管理员组

文章数量: 887021


2023年12月23日发(作者:react副作用需要清除吗)

strcpy()函数

一、strcpy()函数的简介

strcpy()函数:是将一个字符串复制到另一块空间地址中 的函数,‘0’是停止拷贝的终止条件,同时也会将 '0' 也复制到目标空间。下面是库中的strcpy()函数声明:

char* strcpy(char* destination,const char* source);

1. 函数的参数:

char* destination---------目标字符串的首地址

const char* source------源地址:被复制的字符串的首地址,用const修饰,避免修改掉被拷贝的字符串

2.函数的返回值类型:

char*:返回的是目标字符串的首地址

二、strcpy()函数的具体使用

场景一:

#define _CRT_SECURE_NO_WARNINGS

#include

#include

int main()

{

char arr[10] = "########";

printf("%sn", strcpy(arr,"hello"));

return 0;

}

输出的结果

场景二:

#define _CRT_SECURE_NO_WARNINGS

#include

#include

int main()

{

char arr1[10] = "**********";

char arr2[10] = "abcd";

printf("%sn", strcpy(arr1, arr2));

return 0;

}

输出结果

三、使用strcpy()函数的注意事项

1.源字符必须以 '0'结束:

#define _CRT_SECURE_NO_WARNINGS

#include

#include

int main()

{

char arr1[10] = "**********";

char arr2[] = { 'a','b','c','d' };

printf("%sn", strcpy(arr1,arr2));

return 0;

}

这里的代码会出错,'0'是停止拷贝的终止条件,arr2字符数组所在的内存空间后面存储的内容并不知道,不遇到 '0' 拷贝就不会停止,这就会导致越界访问,程序就会出现问题。

2.目标空间必须足够大,以确保能放源字符串

#define _CRT_SECURE_NO_WARNINGS

#include

#include

int main()

{

char arr1[5] = "*****";

char arr2[] = "hello world";

printf("%sn", strcpy(arr1,arr2));

return 0;

}

这里虽然拷贝成功并将结果输出了,但程序却崩溃了。目标空间太小,不足以放置拷贝的源字符串,会造成溢出的情况

3.目标空间必须可变

#define _CRT_SECURE_NO_WARNINGS

#include

#include

int main()

{

char* str1 = "hello world";

char str2[10] = "*********";

printf("%sn", strcpy(str1,str2));

return 0;

}

这里的程序也出现了错误。str1指向的是常量字符串,是不可以被修改掉的,目标空间必须是可以被修改的,因为要将拷贝的字符串放在目标空间中。而源字符串可以是能够修改的、也可以是不能修改的,因为strcpy函数的第二个参数已经用const关键字修饰了,保证了拷贝过程中不会被修改。


本文标签: 字符串 拷贝 目标 函数