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;
}

效果展示:

相关推荐
朝朝又沐沐3 小时前
算法竞赛阶段二-数据结构(36)数据结构双向链表模拟实现
开发语言·数据结构·c++·算法·链表
薰衣草23334 小时前
一天两道力扣(6)
算法·leetcode
逝雪Yuki4 小时前
Leetcode——287. 寻找重复数
c++·leetcode·二分查找·双指针·环形链表
剪一朵云爱着4 小时前
力扣946. 验证栈序列
算法·
遇见尚硅谷4 小时前
C语言:*p++与p++有何区别
c语言·开发语言·笔记·学习·算法
天天开心(∩_∩)4 小时前
代码随想录算法训练营第三十二天
算法
YouQian7724 小时前
(AC)缓存系统
算法·缓存
艾莉丝努力练剑5 小时前
【数据结构与算法】数据结构初阶:详解排序(二)——交换排序中的快速排序
c语言·开发语言·数据结构·学习·算法·链表·排序算法
科大饭桶5 小时前
数据结构自学Day13 -- 快速排序--“前后指针法”
数据结构·算法·leetcode·排序算法·c
李永奉5 小时前
C语言-流程控制语句:for循环语句、while和do…while循环语句;
c语言·开发语言·c++·算法