strcpy防溢出加强版和关于原值的指针与指向原址的指针的思考[C语言]

#include <stdio.h>
#include <string.h>

//防止溢出的strcpy
char* strcpy_enhance(char *dest, const char *src, size_t destSize)
{
    printf("%lld %lld\n", sizeof(dest), destSize);//观察两个值的取值区别
    memset(dest, '\0', destSize);//事实证明入参的格式化宽度只能从外部获取,指针本身和存储指针的指针根本不是一个定义
    size_t len = 0;
    if (strlen(src) <= destSize-1 ) len = strlen(src);
    else len = destSize - 1;
    strncpy(dest, src, len);
    dest[len] = '\0';
    return dest;
}

int main(){
    char chs_dest[30];
    char *pchs_dest = chs_dest;
    strcpy_enhance(pchs_dest, "0d1d2d3d4d5d6d7d8d9d0f1f2f3f4f5f6f7f8f9f", sizeof(chs_dest));//sizeof中不能用指针pchs_dest,指针本身和存储指针的指针根本不是一个定义
    printf("%s\n", pchs_dest);
    return 0;
}

一般在64位系统中,指向某一地址的指针始终是8byte,也就是1byte,而实际数据的地址对应的数据宽度由实际情况而定

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值