内存函数讲解

💕"痛苦难以避免,而磨难可以选择。"-->村上春树💕

作者:Mylvzi

文章主要内容:数据在内存中的存储

内存函数就是管理内存数据的函数,包含于头文件<string.h>中

1.memcpy函数-->内存复制函数(处理不重叠内存的拷贝)

作用:将src中前num个字节拷贝到dest中,并返回dest的地址(和strcpy函数类似)

注意:传递的函数指针不确定,所以使用void*(通用指针类型)

对于void*有四个方面需要注意:

1.不能直接解引用,必须进行强制类型转换

2.不能进行指针运算

3.可以进行指针之间的比大小操作

4.强制类型转换只是一种临时转换,并不会改变原先的数据类型

实例1:

实例2:

模拟实现memcpy函数

cpp 复制代码
//代码模拟实现my_memcp函数
void* my_memcpy(void* dest, const void* src, size_t num)
{
	assert(dest && src);//断言
	void* ret = dest;//使用ret指针记录dest指针的起始位置
	while (num--)
	{
		*(char*)dest = *(char*)src;//强制类型转换为char*,便于一个字节一个字节交换
		dest=(char*)dest+1;
		src=(char*)src+1;
	}
	return ret;
}
int main()
{
	int arr1[] = { 1,2,3,4,5 };//数组的大小为20byte
	int arr2[10] = { 0 };
	my_memcpy(arr2, arr1, 20);//注意第三个参数size_num是以字节为单位的
	int i = 0;
	for (i = 0; i < 10; i++)
	{
		printf("%d ", arr2[i]);
	}
	return 0;
}

注意:memcpy函数是处理不重叠内存的拷贝,也就是不能是同一个数组,不占用相同的一块内存,否则在拷贝的过程中会把原有数据覆盖,导致拷贝错误(虽然在vs中却可以处理,但是在其他编译器上未必支持)

2.memmove函数-->内存拷贝函数(处理重叠内存的拷贝)

模拟实现memmove函数(重要)

cpp 复制代码
//2.memmove函数-->void* memmove(void* dest ,const void* src, size_t num)
//处理内存重叠的内存之间的拷贝
//理解为:将dest和src强行分离为两个独立的内存
//参数和memcpy相同

//模拟实现memove函数
//基本逻辑是从src的某个位置开始,将之后的num个字节的元素赋给dest;
//但可能出现src的元素未被拷贝之前就已经被覆盖(在src和dest重合的部分)
void* my_memmove(void* dest, const void* src, size_t num)
{
	assert(dest && src);//断言
	void* ret = dest;
	//src>dest-->从前往后拷贝
	if (src > dest)
	{
		while (num--)
		{
			*(char*)dest = *(char*)src;
			dest = (char*)dest + 1;
			src = (char*)src + 1;
		}
	}

	//src<dest-->从后往前拷贝(包括src和dest不交叉的情况)
	else
	{
		while (num--)
		{
			*((char*)dest + num) = *((char*)src + num);
			dest = (char*)dest + 1;
			src = (char*)src + 1;
		}
	}
	return ret;
}
int main()
{
	int arr1[] = { 1,2,3,4,5,6,7,8,9,10 };
	my_memmove(arr1, arr1+2, 20);
	int i = 0;		
	for (i = 0; i < 10; i++)
	{
		printf("%d ", arr1[i]);
	}
	return 0;
}

画图模拟:

3.memcmp-->内存比较函数

比较两个内存之间前num个字节的大小关系;

ptr1>ptr2-->返回大于0的数字

ptr1<ptr2-->返回小于0的数字

ptr1=ptr2-->返回0

实例1:

4.memset-->内存设置函数

将ptr中前num个字节的元素替换为设置的value;

实例1:

相关推荐
※DX3906※30 分钟前
Java排序算法--全面详解面试中涉及的排序
java·开发语言·数据结构·面试·排序算法
笨笨马甲1 小时前
Qt QSS使用指南
开发语言·qt
cur1es1 小时前
【JVM类加载&双亲委派模型&垃圾回收机制】
java·jvm·gc·垃圾回收·类加载·双亲委派模型
Mr.朱鹏2 小时前
JVM-GC垃圾回收案例
java·jvm·spring boot·算法·spring·spring cloud·java-ee
焦糖玛奇朵婷2 小时前
实测扭蛋机小程序:开发简单,互动有趣
java·大数据·程序人生·小程序·软件需求
Nan_Shu_6142 小时前
学习: 尚硅谷Java项目之小谷充电宝(3)
java·后端·学习
wzqllwy2 小时前
8 大经典排序算法(Java 实现):原理 + Demo + 核心分析
java·算法·排序算法
智能工业品检测-奇妙智能2 小时前
AIFlowy如何实现与现有Spring Boot项目的无缝集成?
java·spring boot·后端
We་ct2 小时前
LeetCode 77. 组合:DFS回溯+剪枝,高效求解组合问题
开发语言·前端·算法·leetcode·typescript·深度优先·剪枝
從南走到北2 小时前
JAVA无人共享无人健身房物联网结合系统源码支持小程序+公众号+APP+H5
java·物联网·小程序