系列文章目录
深度剖析: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
2void *memcpy(void *dest, const void *src, size_t n);
2.使用详解
memcpy:从 src 复制 count 个字节到 dest
原理详解:
- 内存复制一个一个字节拷贝
- 将每个字节在内存中存储的值进行拷贝
- 不再局限于字符串的拷贝
3.源码剖析
复制代码
1
2
3
4
5
6
7
8
9
10
11
12void *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
2void *memmove (void *destination, const void *source, size_t num);
2.使用详解
memmove:从 src 复制 count 个字节到 dest
原理详解:
- 与memcpy的差别就是memmove函数处理的源内存块和目标内存块是可以重叠的
- 如果源空间和目标空间出现重叠,就得使用memmove函数处理
3.源码剖析
复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18void *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的全部内容,更多相关深度剖析内容请搜索靠谱客的其他文章。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复