c语言:有关内存函数的模拟实现

memcpy函数:

功能: 复制任意类型的数据,存储到某一数组中。

代码模拟实现功能:

cpp 复制代码
 #define  _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<string.h>
#include <stdio.h>
#include<assert.h>
memcpy
void* my_memcpy(void* dest, const void* src, size_t num)
{
	void* ret = dest;
	assert(dest && src);
	while (num--)
	{
		*(char*)dest = *(char*)src;
		dest = (char*)dest + 1;
		src = (char*)src + 1;
	}
	return ret;
}
int main()
{
	int arr1[10] = { 1,2,3,4,5,6,7,8,9,10 };
	my_memcpy(arr1, arr1+2, 5 * sizeof(int));
	int i = 0;
	for (i = 0; i < 10; i++)
	{
		printf("%d ", arr1[i]);// 1 2 1 2 3 4 5 8 9 10
	}

	return 0;
}

效果展示:

memmove函数:

功能:按照指定内容的大小替换掉指定内容。

代码模拟实现功能:

cpp 复制代码
#define  _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<string.h>
#include <stdio.h>
#include<assert.h>
memcpy

//
//
//memmove
void*  my_memove(void* dest, const void* src, size_t num)//void* 可以拷贝任意类型的数据,整型,字符,结构体
{
	void* ret = dest;
	assert(dest && src);
	if (dest < src)
	{
		//前-》后
		while (num--)
		{
			*(char*)dest = *(char*)src;//赋值,转化为char*的原因:不知道传进来的是什么类型,需要复制多少字节,因此用最小字节char*来转化
			dest = (char*)dest + 1;
			src = (char*)src + 1;//循环完一次,都找下一个字节
		}
	}
	else
	{
		//后-》前
		while (num--)
		{
			*((char*)dest+num) = *((char*)src + num);//赋值,和上面同理,但是是从后面往前赋值。
		}
	}
	return ret;
}

int main()
{
	int arr1[10] = { 1,2,3,4,5,6,7,8,9,10 };
	my_memove(arr1, arr1+2, 5 * sizeof(int));
	int i = 0;
	for (i = 0; i < 10; i++)
	{
		printf("%d ", arr1[i]);
	}
	return 0;
}

效果展示:

相关推荐
aaaweiaaaaaa17 分钟前
c++基础学习(学习蓝桥杯 ros2有C基础可看)
c++·学习·蓝桥杯·lambda·ros2·智能指针·c++类
skytier25 分钟前
Construct内报错和定位解决
算法
skytier30 分钟前
Ascend print数据落盘使用
算法
一拳一个呆瓜39 分钟前
【MFC】对话框属性:字体 (Font Name) 和 大小 (Font Size)
c++·mfc
etcix1 小时前
dmenux.c: integrate dmenu project as one file
c语言·前端·算法
papership1 小时前
【入门级-算法-6、排序算法:选择排序】
数据结构·算法·排序算法
郝学胜-神的一滴1 小时前
基于OpenGL封装摄像机类:视图矩阵与透视矩阵的实现
c++·qt·线性代数·矩阵·游戏引擎·图形渲染
啊?啊?1 小时前
14 C++ STL 容器实战:stack/list 模拟实现指南 + priority_queue 用法及避坑技巧
c++·
汉克老师1 小时前
第十四届蓝桥杯青少组C++选拔赛[2023.2.12]第二部分编程题(4、最大空白区)
c++·算法·蓝桥杯·蓝桥杯c++·c++蓝桥杯
共享家95271 小时前
优先搜索(DFS)实战
算法·leetcode·深度优先