字符串复制函数:
strcpy(目标字符串的首地址,被复制的字符串的首地址)
复制p到a:
char * p="12345";
char a[20];
strcpy(a, p);
printf("%s\n", a);
strcpy_s(目标字符串的首地址,缓冲长度,被复制的字符串的首地址)
strcpy_s(a, 20, p);//20为缓冲长度 可用空间的长度
printf("%s\n", a);
strncpy(目标字符串的首地址,被复制的字符串的首地址,复制的长度) ,这种复制方式更像是覆盖
strncpy(a, "123456", 4);
strncpy_s(目标字符串的首地址,缓冲长度,被复制的字符串的首地址,,复制的长度),清零后复制
strncpy_s(a, 20, "123456", 4);
仿真字符串复制函数 strcpy
char* my_strcpy(char* dest, const char* src);
char* my_strcpy(char* dest, const char* src)
{
char* p_dest = dest;
const char* p_src = src;
while (*p_src)//!='\0'
{
*p_dest = *p_src;
p_src++;
p_dest++;
}
*p_dest = '\0';
return dest;
}
测试:
printf("%s\n", my_strcpy(a, "how are you"));
仿真字符串复制函数 strncpy
char* my_strncpy(char* dest, const char* src, unsigned num);
char* my_strncpy(char* dest, const char* src, unsigned num)
{
char* p_dest = dest;
const char* p_src = src;
int i = 0;
while (*p_src && i++ < num)//!='\0'
{
*p_dest = *p_src;
p_src++;
p_dest++;
}
//*p_dest = '\0';
return dest;
}
测试:
my_strncpy(a, "123456", 4);
完整代码:
#include <stdio.h>
#include <string.h>
char* my_strcpy(char* dest, const char* src);
char* my_strncpy(char* dest, const char* src, unsigned num);
int main ()
{
/*字符串复制函数*/
char * p="12345";
char a[20];
/*strcpy*/
//a=p;
strcpy(a, p);
printf("%s\n", a);
printf("%s\n", my_strcpy(a, "how are you"));
printf("%d\n", strlen(strcpy(a, "how old are you")));
/*strcpy_s*/
strcpy_s(a, 20, p);//20为缓冲长度 可用空间的长度
printf("%s\n", a);
/*strncpy*/
my_strncpy(a, "123456", 4);//像是覆盖
strncpy(a, "123456", 4);//像是覆盖
printf("%s\n", a);
/*strncpy_s*/
strncpy_s(a, 20, "123456", 4);//清零后复制
printf("%s\n", a);
/*仿真字符串复制函数 strcpy */
return 0;
}
char* my_strcpy(char* dest, const char* src)
{
char* p_dest = dest;
const char* p_src = src;
while (*p_src)//!='\0'
{
*p_dest = *p_src;
p_src++;
p_dest++;
}
*p_dest = '\0';
return dest;
}
char* my_strncpy(char* dest, const char* src, unsigned num)
{
char* p_dest = dest;
const char* p_src = src;
int i = 0;
while (*p_src && i++ < num)//!='\0'
{
*p_dest = *p_src;
p_src++;
p_dest++;
}
//*p_dest = '\0';
return dest;
}
完整输出: