我是靠谱客的博主 奋斗白猫,这篇文章主要介绍深度剖析 string —— memcpy & memmove系列文章目录前言一、memcpy二、memmove,现在分享给大家,希望可以做个参考。

系列文章目录

深度剖析:strcat & strncat
深度剖析:strchr & strstr
深度剖析:strcmp & strncmp
深度剖析:strcpy & strncpy
深度剖析:strlen & strtok
深度剖析:memcpy & memmove
深度剖析:memset & memcmp


文章目录

  • 系列文章目录
  • 前言
  • 一、memcpy
    • 1.调用结构
    • 2.使用详解
    • 3.源码剖析
  • 二、memmove
    • 1.调用结构
    • 2.使用详解
    • 3.源码剖析


前言

库函数string是我们经常使用也是非常重要的代码,我将会对常用的函数的用法和实现原理进行深度剖析


一、memcpy

1.调用结构

复制代码
1
2
void *memcpy(void *dest, const void *src, size_t n);

2.使用详解

memcpy:从 src 复制 count 个字节到 dest

原理详解:

  1. 内存复制一个一个字节拷贝
  2. 将每个字节在内存中存储的值进行拷贝
  3. 不再局限于字符串的拷贝

3.源码剖析

复制代码
1
2
3
4
5
6
7
8
9
10
11
12
void *Memcpy(void *dest, const void *src, size_t count) { //内存复制:从 src 复制 count 个字节到 dest assert(dest && src); char *start = dest; //记录起始位置的地址 while (count--) { //拷贝的字节数 *(char *) dest = *(char *) src; //一个字节一个字节进行拷贝 dest = (char *) dest + 1; src = (char *) src + 1; } return start; //返回起始位置的地址 }

二、memmove

1.调用结构

复制代码
1
2
void *memmove (void *destination, const void *source, size_t num);

2.使用详解

memmove:从 src 复制 count 个字节到 dest

原理详解:

  1. 与memcpy的差别就是memmove函数处理的源内存块和目标内存块是可以重叠的
  2. 如果源空间和目标空间出现重叠,就得使用memmove函数处理

3.源码剖析

复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
void *Memmove(void *dest, void *src, int count) { //内存复制:从 src 复制 count 个字节到 dest assert(dest && src); //防止传入空指针 char *start = dest; if (dest < src) { //前->后 while (count--) { *(char *) dest = *(char *) src; dest = (char *) dest + 1; src = (char *) src + 1; } } else { //后->前 while (count--) { *((char *) dest + count) = *((char *) src + count); } } return start; }

最后

以上就是奋斗白猫最近收集整理的关于深度剖析 string —— memcpy & memmove系列文章目录前言一、memcpy二、memmove的全部内容,更多相关深度剖析内容请搜索靠谱客的其他文章。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(84)

评论列表共有 0 条评论

立即
投稿
返回
顶部