IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> C++知识库 -> memcpy与memmove的模拟实现与应用 -> 正文阅读

[C++知识库]memcpy与memmove的模拟实现与应用

1.memcpy

eg(memcpy):memmem

#include<stdio.h>
#include<assert.h>
int main()
{
	int arr3[] = { 1,2,3,4,5,6,7,8,9,10 };
	int arr4[5] = { 0 };
	memcpy(arr4, arr3, sizeof(arr3[0]) * 5);
 //memcpy(arr4, arr3+5, sizeof(arr3[0]) * 5);也可以
//函数原型:void* memcpy(void* dest, const void* src, size_t n);
//功能:由src指向地址为起始地址的连续n个字节的数据
//复制到以destin指向地址为起始地址的空间内。
	int i = 0;
	for (i = 0; i < 5; i++)
	{
		printf("%d\n", arr4[i]);
	}
	return 0;
}

memcpy的模拟实现

#include<stdio.h>
#include<assert.h>
void* my_memcpy(void* dest,const void* src, size_t num)
{
	assert(dest && src);
	void* ret = dest;
	while (num--)
	{
		*(char*)dest = *(char*)src;//注意强制类型转换都是临时
		dest = (char*)dest + 1;
		//void*的指针不能进行加加减减操作,需要进行强制类型转换
		src = (char*)src + 1;
	}
	return ret;
}

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

memcpy的应用

描述
输入两个升序排列的序列,将两个序列合并为一个有序序列并输出。
输入描述:
输入包含三行,
第一行包含两个正整数n, m,用空格分隔。n表示第二行第一个升序序列中数字的个数,m表示第三行第二个升序序列中数字的个数。第二行包含n个整数,用空格分隔。第三行包含m个整数,用空格分隔。
输出描述:
输出为一行,输出长度为n + m的升序序列,
即长度为n的升序序列和长度为m的升序序列中的元素重新进行升序序列排列合并。
?

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
int compare(const void* a, const void* b)
{
	return (*(int*)a - *(int*)b);
	//compare从小到大排序
}
int main()
{
	//输入
	int n = 0;
	int m = 0;
	scanf("%d %d", &n, &m);
	int arr1[20] = { 0 };
	int arr2[10] = { 0 };
	int i = 0;
	int j = 0;
	for (i = 0; i < n; i++)
	{
		scanf("%d", &arr1[i]);
	}
	for (j = 0; j < m; j++)
	{
		scanf("%d", &arr2[j]);
	}
	int sz = m + n;
	//把两个整形数组合并
	memcpy(arr1+n, arr2, sizeof(arr2[0]) * m);
	//排序
	qsort(arr1, sz, sizeof(arr1[0]), compare);
	//打印
	int k = 0;
	for (k = 0; k < sz; k++)
	{
		printf("%d ", arr1[k]);
	}
	return 0;
}

2.memmove

?memmove与memcpy的区别

memcpy与memmove的区别 - 简书 (jianshu.com)

????????由此可见memcpy的速度比memmove快一点,如果使用者可以确定内存不会重叠,则可以选用memcpy,否则memmove更安全一些。

memmove的模拟实现

?

#include<stdio.h>
#include<assert.h>
void* my_memmove(void* dest, const void* src, size_t num)
{
	void* ret = dest;
	assert(dest && src);
	if (dest < src)
	//地址从低到高
	{
		//前—》后
		while (num--)
		{
			*(char*)dest = *(char*)src;
			dest = (char*)dest + 1;
			src = (char*)src + 1;
		}
	
	}
	else
	{
		//后—》前
		//04 00 00 00 | 05 00 00 00 | 06 00 00 00 | 07 00 00 00
		while (num--)
		//如果num是4,4321进来,但是1进了while循环之后会再减去一变成0,
		//那么下次就不会再进入while循环了
		//注意num--是先取值再自减
		{
			*((char*)dest +num) = *((char*)src + num);
			//*((char*)src + num)相当于找到了最后的00字节
			//一个字节一个字节的进行拷贝才具有代表性
			
		}
		
	}
	return ret;
}

int main()
{
	int arr3[] = { 1,2,3,4,5,6,7,8,9,10 };
	
	//void* my_memmove(void* dest, const void* src, size_t num)终点,起点,字节
	my_memmove(arr3 + 2, arr3, sizeof(int)*5);//dest>src,从后向前拷贝是指src从后往前拷贝
	//1 2 1 2 3 4 7 8 9 10
	//my_memmove(arr3, arr3 + 2, 20);//dest<src

	int i = 0;
	for (i = 0; i < 10; i++)
	{
		printf("%d\n", arr3[i]);
	}
	return 0;
}

  C++知识库 最新文章
【C++】友元、嵌套类、异常、RTTI、类型转换
通讯录的思路与实现(C语言)
C++PrimerPlus 第七章 函数-C++的编程模块(
Problem C: 算法9-9~9-12:平衡二叉树的基本
MSVC C++ UTF-8编程
C++进阶 多态原理
简单string类c++实现
我的年度总结
【C语言】以深厚地基筑伟岸高楼-基础篇(六
c语言常见错误合集
上一篇文章      下一篇文章      查看所有文章
加:2022-04-09 18:05:39  更:2022-04-09 18:06:08 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 21:05:06-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码