模拟实现 strcpy(字符串拷贝) --浅谈C语言

cnblogs 2024-08-05 08:39:00 阅读 84

C 库函数 - strcpy()

目录

    <li>C 库函数 - strcpy()
    • 描述
    • 声明
    • 参数
    • 返回值
    • 模拟实现
      • 1.0
      • 2.0
      • 3.0
      • 4.0
      • 5.0

描述

char *strcpy(char *dest, const char *src)src 所指向的字符串复制到 dest

需要注意的是如果目标数组 dest 不够大,而源字符串的长度又太长,可能会造成缓冲溢出的情况。

声明

下面是 strcpy() 函数的声明。

<code>char *strcpy(char *dest, const char *src)

参数

    <li>dest -- 指向用于存储复制内容的目标数组。
  • src -- 要复制的字符串。

返回值

该函数返回一个指向最终的目标字符串 dest 的指针。

模拟实现

1.0

void my_strcpy(char* dest, char* src)//版本一

{

while (*src != '\0')

{

*dest = *src;

src++;

dest++;

}

*dest = *src;

}

2.0

// 满足递进关系与后置++,简化代码

//(缺点,指针解引用前无保护)

void my_strcpy(char* dest, char* src)

{

while (*dest++ = *src++) //'\0' 为假,控制循环

;

}

3.0

//优化三:在解引用指针前,判断指针的有效性(必须)

//(虽防止出现野指针,但没提示出哪里出错)

void my_strcpy(char* dest, char* src)

{

if (src != NULL&&dest != NULL)

{

while (*dest++ = *src++)

;

}

}

4.0

//编写代码时,我们总是会做出一些假设,断言就是用于在代码中捕捉这些假设,可以将断言看作是异常处理的一种高级形式。

#include<assert.h>

void my_strcpy(char* dest, char* src)//法四:断言法(在保护的基础上,告诉错误在哪)

{

assert(dest != NULL); //fail(失败,不成功)

assert(src != NULL);

if (src != NULL){

while (*dest++ = *src++);

}

}

5.0

//优化五:常变量修饰参数与返回值类型

//1、为防止下面表达式写错,用const限制*src不能被修改(防止*dest赋给*src)

//2、确保结果与目标相同,将返回目的地(结果)的地址,便于后续操作验证与使用

#include<assert.h>

char* my_strcpy(char* dest, const char* src)

{

char* ret = dest; //在开始前就保存好目的地地址,便于后续修改后可以找到起点

assert(dest != NULL);

assert(src);//(NULL==0)

if (src != NULL){

while (*dest++ = *src++);

}

return ret;

}

intmain()

{

char arr1[] = "##############";

char arr2[] = "hello";

my_strcpy(arr1, NULL); //此处错误还没改

printf("%s\n", arr1);

printf("%s\n", my_strcpy(arr1, NULL)); //最终版本 //函数的返回值作为另一个函数的参数(链式访问)

return 0;

}



声明

本文内容仅代表作者观点,或转载于其他网站,本站不以此文作为商业用途
如有涉及侵权,请联系本站进行删除
转载本站原创文章,请注明来源及作者。