头文件:
string.h
用法:
char*strcpy(char*dest,const char*src)
将目标(被粘贴的)字符数组名输入第一个位置,将要拷贝的字符数组名输入第二个位置。
效果:
将拷贝的字符数组中的字符串拷贝到另一个目标字符数组。
返回值:
返回目标字符数组的地址。
例子:
将str1复制到str2字符数组中
#include<string.h>
int main() {
char str1[10] = "hello";
char str2[10] = "";
strcpy(str2, str1);
printf("%s\n", str2);
}
函数的实现:
#include<stdio.h>
void my_strcpy(char* dest, char* src) {
while (*src != '\0') {
*dest = *src;
dest++;
src++;
}
}
int main() {
char str1[10] = "hello";
char str2[10] = "";
my_strcpy(str2, str1);
printf("%s\n", str2);
}
我们知道strcpy函数将原来的字符数组字符串结尾的\0也复制。
我们可以进行改进
#include<stdio.h>
void my_strcpy(char* dest, char* src) {
while (*src != '\0') {
*dest = *src;
dest++;
src++;
}
*dest = *src; //将结尾的\0在复制过去
}
int main() {
char str1[10] = "hello";
char str2[10] = "";
my_strcpy(str2, str1);
printf("%s\n", str2);
}
还可以将while中的语句整合一下
void my_strcpy(char* dest, char* src) {
while (*dest++ = *src++) {
;
}
*dest = *src;
}
这样看起来已经完成了但是,还是有些欠缺
若传过去的是空指针,那么解引用的时候,没有可读取的地址,会出现错误。
我们可以引用assert函数来避免这个现象
#include<assert.h>//注意头文件
void my_strcpy(char* dest, char* src) {
assert(dest != NULL && src != NULL);//当出现空指针传参时,该表达式为假,无法执行程序
while (*dest++ = *src++) {
;
}
*dest = *src;
}
对比这个声明,我们还有const,char*,这些地方需要改进。
void my_strcpy(char* dest,conest char* src) {//加上conest使要拷贝的字符数组中
//存放的字符串不可改变
assert(dest != NULL && src != NULL);
while (*dest++ = *src++) {
;
}
*dest = *src;
}
同时防止拷贝时出现"拷贝反了"的现象
最终完善形式 :
char* my_strcpy(char* dest,const char* src) {
assert(dest != NULL && src != NULL);
char* ret = dest; //将首地址储存,在之后dest后置++运算中,可以方便找到
while (*dest++ = *src++) { //目标数组的首地址
;
}
*dest = *src;
return ret;
}
这样将返回值设为目标字符数组首地址,用起来更方便
如:
#include<stdio.h>
#include<assert.h>
char* my_strcpy(char* dest,const char* src) {
assert(dest != NULL && src != NULL);
char* ret = dest;
while (*dest++ = *src++) {
;
}
*dest = *src;
return dest;
}
int main() {
char str1[10] = "hello";
char str2[10] = "";
printf("%s",my_strcpy(str2, str1));//因为返回首地址,所以可以直接打印使用
}