strcpy()函数:是将一个字符串复制到另一块空间地址中 的函数,‘\0’是停止拷贝的终止条件,同时也会将 '\0' 也复制到目标空间。下面是库中的strcpy()函数声明:
char* strcpy(char* destination,const char* source);
1. 函数的参数:
2.函数的返回值类型:
场景一:
#define _CRT_SECURE_NO_WARNINGS #include <stdio.h> #include <string.h> int main() { char arr[10] = "########"; printf("%s\n", strcpy(arr,"hello")); return 0; }
输出的结果
场景二:
#define _CRT_SECURE_NO_WARNINGS #include <stdio.h> #include <string.h> int main() { char arr1[10] = "**********"; char arr2[10] = "abcd"; printf("%s\n", strcpy(arr1, arr2)); return 0; }
输出结果
1.源字符必须以 '\0'结束:
#define _CRT_SECURE_NO_WARNINGS #include <stdio.h> #include <string.h> int main() { char arr1[10] = "**********"; char arr2[] = { 'a','b','c','d' }; printf("%s\n", strcpy(arr1,arr2)); return 0; }
这里的代码会出错,'\0'是停止拷贝的终止条件,arr2字符数组所在的内存空间后面存储的内容并不知道,不遇到 '\0' 拷贝就不会停止,这就会导致越界访问,程序就会出现问题。
2.目标空间必须足够大,以确保能放源字符串
#define _CRT_SECURE_NO_WARNINGS #include <stdio.h> #include <string.h> int main() { char arr1[5] = "*****"; char arr2[] = "hello world"; printf("%s\n", strcpy(arr1,arr2)); return 0; }
这里虽然拷贝成功并将结果输出了,但程序却崩溃了。目标空间太小,不足以放置拷贝的源字符串,会造成溢出的情况
3.目标空间必须可变
#define _CRT_SECURE_NO_WARNINGS #include <stdio.h> #include <string.h> int main() { char* str1 = "hello world"; char str2[10] = "*********"; printf("%s\n", strcpy(str1,str2)); return 0; }
这里的程序也出现了错误。str1指向的是常量字符串,是不可以被修改掉的,目标空间必须是可以被修改的,因为要将拷贝的字符串放在目标空间中。而源字符串可以是能够修改的、也可以是不能修改的,因为strcpy函数的第二个参数已经用const关键字修饰了,保证了拷贝过程中不会被修改。
strcpy()的返回类型是char *,该函数返回的是一个字符的地址。
第一个参数不必指向数组的开始,这个特性可用于拷贝数组的一部分。
下面这个程序演示了将一个字符串拷贝到另一个字符数组的指定位置:
/* * @Author: Your name * @Date: 2020-02-24 14:35:13 * @Last Modified by: Your name * @Last Modified time: 2020-02-24 15:26:57 */ #include<stdio.h> #include<stdlib.h> #include<string.h> #define WORDS "beast" #define SIZE 40 int main() { const char * orig = WORDS; char copy[SIZE] = "Be the best that you can be."; char * ps; puts(orig); puts(copy); ps = strcpy(copy+7,orig);//ps==©[7],第八个元素的地址。 puts(copy); puts(ps); getchar(); return 0; }
下面是该程序的输出:
beast
Be the best that you can be.
Be the beast
beast
注意:
具体如下: