C++ strcpy函数
函数功能把含有'\0'结束符的字符串复制到另一个地址空间。
函数声明:char *strcpy(char* dest, const char *src);
把以src为首地址NULL为结束符的数据复制到以dest开始的地址,但是,src与dest空间不能有重叠,且dest必须有足够的空间。
C++提供strcpy此类函数,为了对指针操作更加安全,避免内存泄露等异常状态的发生。
例如:
char *p=new char[10];
p="hello";
delete p[]; //此步释放时将报错❌ ;这种做法是错误的
在C++中,字符串常量"hello"被保存在常量存储区,而p="hello"操作是改变了指针的指向,
使得指针p指向了常量存储区的"hello",造成了初始在堆上开辟的内存泄露,
而delete无法释放常量存储区的内存,导致出错。
正确操作:
char *p=new char[10];
strcpy(p,"hello");
delete p[]; //正确做法
使用strcpy函数把字符串常量"hello"赋值到p指向的空间中(初始化在堆上开辟空间)。
———————————————————————————————————————————
参考链接:https://blog.csdn.net/great_emperor_/article/details/123178868
———————————————————————————————————————————
与此相关的Demo测试:
Demo1:
//strcpy函数是字符串拷贝,传入的第一个字符串是接收拷贝的字符串,
//第二个字符串是要被拷贝的字符串,我们不需要保护第一个字符串,
//但是我们不希望第二个字符串被修改,所以在第二个传参的时候加上const。
//
//assert是断言,判断传入的字符串是否合法(是否不为空指针),如果是空指针则进行报错
#define _CRE_SECURE_N0_WARNINGS
#include<stdio.h>
#include<string.h>
#include<assert.h>
char* my_strcpy(char* dest, const char* str)
{
assert(*dest != NULL);
assert(*str != NULL);
char* ret = dest;
//拷贝str指向的字符串到dest指向的空间,包含'\0'
int m_i = 1;
while (*dest++ = *str++)
{
printf("%d\n", m_i++);
}
//返回目的空间的起始地址
return ret;
}
int main()
{
char arr1[] = "abcdefghi";
char arr2[] = "bit";
my_strcpy(arr1, arr2);
printf("%s\n", arr1);
printf("%s\n", arr2);
getchar();
return 0;
}
运行结果如下:
Demo2:
#include<stdio.h>
#include<string.h>
int main()
{
char arr1[] = "abcdefghi";
char arr2[] = "bit";
printf("%s\n", arr1);
//字符串拷贝
strcpy_s(arr1, arr2);
printf("%s\n", arr1);
printf("%s\n", arr2);
getchar();
return 0;
}
运行结果如下: