C语言中的字符串函数有如下这些

  • 获取字符串长度

    • strlen
  • 长度不受限制的字符串函数
    • strcpy
    • strcat
    • strcmp
  • 长度受限制的字符串函数
    • strncpy
    • strncat
    • strncmp
  • 字符串查找
    • strstr
    • strtok
  • 错误信息报告
    • strerror

接下来看看如何实现它们

长度不受限制的字符串函数

strcpy

我们看看文档是怎样说的,如下

strcpy文档

char * strcpy ( char * destination, const char * source );

Copy string

字符串拷贝(字符串复制)

Copies the C string pointed by source into the array pointed by destination, including the terminating null character (and stopping at that point).

复制由字符指针source指向的C字符串到另一个字符数组中,该字符数组字符指针destination指向

To avoid overflows, the size of the array pointed by destination shall be long enough to contain the same C string as source (including the terminating null character), and should not overlap in memory with source.

为避免溢出,由destination指向的字符数组的大小需要足够长,足够包含住源字符串(包含'\0')

综上,可以知道

  1. 会将源字符串中的 '\0' 拷贝到目标空间,源字符串必须以 '\0' 结束。
  2. 目标空间必须足够大,以确保能存放源字符串。

怎么实现拷贝?

int main()
{
char arr1[] = "abcdefghi";
char arr2[] = "bit";
// 把arr2的内容拷贝到arr1中
//strcpy(arr1, arr2);
// 怎么拷贝? my_strcpy(arr1, arr2);
printf("%s\n", arr1);
return 0;
}

实现

断言指针不为空是个好习惯~

//char* my_strcpy(char* dest, char* src)
// src加上const,为什么?因为我们只需要拷贝,不需要改动源字符串,防止发生修改,所以加上const修饰
char* my_strcpy(char* dest, const char* src)
{
assert(dest != NULL);
assert(src != NULL); while (*src != '\0')
{
*dest = *src;
dest++;
src++;
}
*dest = *src; // '\0'
// 返回目的空间的起始地址
return dest;
}

源字符串拷贝到目的空间,寻找'\0',不是'\0'的就执行*dest = *src,把源字符赋值给目的空间,然后两个指针都往后偏移,也就是都进行++,当*src为'\0'时,说明源字符串已经到结尾了,就退出这个循环,直接将'\0'赋值给*dest,最后返回dest

可以进行优化,如下

char* my_strcpy(char* dest, const char* src)
{
assert(dest != NULL);
assert(src != NULL);
// 优化
while (*src != '\0')
{
*dest++ = *src++;
}
*dest = *src; // '\0'
// 返回目的空间的起始地址
return dest;
}

当然还可以继续优化,变得更加简洁,直接将*dest++ = *src++作为判断条件,同时还会执行操作,如下

char* my_strcpy(char* dest, const char* src)
{
assert(dest != NULL);
assert(src != NULL);
// 优化
// 拷贝src指向的字符串到dest指向的空间,包含'\0'
char* rest = dest;
while (*dest++ = *src++)
{
;
}
// 返回目的空间的起始地址
return rest;
}

C语言-字符串函数的实现(二)之strcpy的更多相关文章

  1. 13-C语言字符串函数库

    目录: 一.C语言字符串函数库 二.用命令行输入参数 回到顶部 一.C语言字符串函数库 1 #include <string.h> 2 字符串复制 strcpy(参数1,参数2); 参数1 ...

  2. C语言字符串函数大全

    C语言字符串函数大全 函数名: stpcpy 功 能: 拷贝一个字符串到另一个 用 法: char *stpcpy(char *destin, char *source); 程序例: #include ...

  3. 07 --C语言字符串函数

    1)字符串操作  复制 strcpy(p, p1)      复制字符串 strncpy(p, p1, n)  复制指定长度字符串 strdup(char *str)      将串拷贝到新建的位置处 ...

  4. C语言-字符串函数的实现(一)之strlen

    C语言中的字符串函数有如下这些 获取字符串长度 strlen 长度不受限制的字符串函数 strcpy strcat strcmp 长度受限制的字符串函数 strncpy strncat strncmp ...

  5. C语言-字符串函数的实现(五)之strstr

    C语言中的字符串函数有如下这些 获取字符串长度 strlen 长度不受限制的字符串函数 strcpy strcat strcmp 长度受限制的字符串函数 strncpy strncat strncmp ...

  6. C语言字符串函数例子程序大全 – string相关

    关于字符串函数的应用细则,例子程序 – jerny 函数名: stpcpy 功 能: 拷贝一个字符串到另一个 用 法: char *stpcpy(char *destin, char *source) ...

  7. 【C++实现python字符串函数库】二:字符串匹配函数startswith与endswith

    [C++实现python字符串函数库]字符串匹配函数startswith与endswith 这两个函数用于匹配字符串的开头或末尾,判断是否包含另一个字符串,它们返回bool值.startswith() ...

  8. c语言字符串函数详解

    转载请注明来源:https://www.cnblogs.com/hookjc/ oid *memset(void *dest, int c, size_t count); 将dest前面count个字 ...

  9. 关于C语言字符串函数使用的一点心得

    就字符串的拼接函数为例strcat. 原型:extern char *strcat(char *dest,char *src);用法:#include <string.h> 功能:把src ...

随机推荐

  1. Java 开源办公开发平台 O2OA V5.4.0 发布 | 设计元素搜索功能上线

    O2OA V5.4.0版本此次更新的设计元素搜索功能,可以让用户在海量的脚本.页面.表单.视图等信息中迅速锁定有价值的信息,以便提高用户获取信息的效率.拥有此搜索功能后,在开发过程中,可以加速定位脚本 ...

  2. three.js cannon.js物理引擎之ConvexPolyhedron多边形

    年后第一天上班,郭先生来说一说cannon.js的ConvexPolyhedron(多边形),cannon.js是一个物理引擎,内部通过连续的计算得到各个时间点的数据的状态,three.js的模型可以 ...

  3. 谁手握账本?趣讲 ZK 的内存模型

    本文作者:HelloGitHub-老荀 Hi,这里是 HelloGitHub 推出的 HelloZooKeeper 系列,免费开源.有趣.入门级的 ZooKeeper 教程,面向有编程基础的新手. 本 ...

  4. Oracle 开启或关闭归档

    开启:sqlplus / as sysdbaarchive log list;shutdown immediate;startup mount;alter database archivelog;ar ...

  5. React源码 commit阶段详解

    转: React源码 commit阶段详解 点击进入React源码调试仓库. 当render阶段完成后,意味着在内存中构建的workInProgress树所有更新工作已经完成,这包括树中fiber节点 ...

  6. 《C++ Primer》笔记 第8章 IO库

    iostream定义了用于读写流的基本类型,fstream定义了读写命名文件的类型,sstream定义了读写内存string对象的类型. 标准库使我们能忽略这些不同类型的流之间的差异,这是通过继承机制 ...

  7. HDOJ-1560(迭代加深搜索问题)

    DNA sequence HDOJ-1560 *本题是迭代加深搜索问题,主要是要理解题目,题目中一定是有解的,所以为了找最小的解,可以从小的搜索深度开始逐渐增加. *这里有个技巧就是,如果本次指定开始 ...

  8. RocketMQ安装配置过程

    官网 官方网站:http://rocketmq.apache.org 下载源码包:https://www.apache.org/dyn/closer.cgi?path=rocketmq/4.8.0/r ...

  9. FreeBSD ibus输入法框架配置

    FreeBSD ibus输入法框架配置 ibus输入法框架配置.xinitrc中增加XIM=ibus; export XIMGTK_IM_MODULE=ibus; export GTK_IM_MODU ...

  10. 「NOIP模拟赛」Round 2

    Tag 递推,状压DP,最短路 A. 篮球比赛1 题面 \(Milky\ Way\)的代码 #include <cstdio> const int N = 2000, xzy = 1e9 ...