我是靠谱客的博主 奋斗白猫,最近开发中收集的这篇文章主要介绍深度剖析 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.调用结构
void *memcpy(void *dest, const void *src, size_t n);
2.使用详解
memcpy:从 src 复制 count 个字节到 dest
原理详解:
- 内存复制一个一个字节拷贝
- 将每个字节在内存中存储的值进行拷贝
- 不再局限于字符串的拷贝
3.源码剖析
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.调用结构
void *memmove (void *destination, const void *source, size_t num);
2.使用详解
memmove:从 src 复制 count 个字节到 dest
原理详解:
- 与memcpy的差别就是memmove函数处理的源内存块和目标内存块是可以重叠的
- 如果源空间和目标空间出现重叠,就得使用memmove函数处理
3.源码剖析
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的全部内容,希望文章能够帮你解决深度剖析 string —— memcpy & memmove系列文章目录前言一、memcpy二、memmove所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复