首先你要看一下两个函数的实现源码。
情况一:
char* p="how are you ?";
char name[20]="ABCDEFGHIJKLMNOPQRS";
strcpy(name,p); //name改变为"how are you ? OPQRS " ====>错误!
strncpy(name,p,sizeof(name)) //name改变为"how are you ? " ====>正确!
情况二:
char* p="how are you ?";
char name[20];
strcpy(name,p); //name改变为"how are you ? 未知字符 " ====>错误!
name[sizeof(name)-1]='/0' //和上一步组合,得到正确的结果!
strncpy(name,p,sizeof(name)); //name改变为"how are you ? " ====>正确!
情况三:
char* p="how are you ?";
char name[10];
strcpy(name,p); //name改变为"how are yo" ====>无结束符'/0',错误!
name[sizeof(name)-1]='/0' //和上一步组合,弥补结果。但要注意,字符传递错误!
strncpy(name,p,sizeof(name)); //和单纯的一步strcpy结果一样!
分析结果:strcpy
如果源长>目标长,则将源长中等于目标长的字符拷贝到目标字符串
如果源长<目标长,则源长全部拷贝到目标字符串,不包括'/0'
strncpy
如果目标长>指定长>源长,则将源长全部拷贝到目标长,自动加上'/0'
如果指定长<源长,则将源长中按指定长度拷贝到目标字符串,不包括'/0'
如果指定长>目标长,error happen!
改进后的strncpy
{
if( dest != NULL || src != NULL ){
printf("error\n");
}
size_t i;
for(i = 0; i < (n-1) && src[i] != '\0'; i++ ) { /*有极值限制,在遇到\0后第一时间退出,并保证最后一个字符为\0,拿走不谢!*/
dest[i] = src[i];
}
dest[i] = '\0';
return i;
}
void main (void)
{
char a[10];
char *b = "11111";
new_strncpy(a,b,10);
printf("a = %s\n",a);
}
这样修改后,就不会出现溢出的情况了