一个重写的strncpy(strcpy和strncpy比较)

本文通过三种情况对比了strcpy和strncpy的使用效果,指出了strcpy可能导致的字符串溢出问题,而strncpy在适当参数下能避免该问题。分析了strncpy的复制特性,并提出了改进后的strncpy实现,以确保不会出现溢出状况。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

首先你要看一下两个函数的实现源码。

情况一:
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


#include "stdio.h"


int new_strncpy(char *dest, char *src, int n)
{
    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);

}

这样修改后,就不会出现溢出的情况了

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值