【memcpy函数的介绍与使用和模拟实现】

memcpy函数的介绍与使用和模拟实现

1.memcpy函数的介绍

资源来源于cplusplus网站

它的作用是:

将数字字节的值从源指向的位置直接复制到目标指向的内存块。

源指针和目标指针指向的对象的基础类型与此函数无关; 结果是数据的二进制副本。

该函数不检查源代码中是否有任何终止空字符-它总是准确地复制 num 字节。

为了避免溢出,目标参数和源参数所指向的数组的大小应至少为 num 字节,并且不应该重叠(对于重叠的内存块,memmove 是一种更安全的方法)。

简化:内存复制,拷贝。

2.memcpy函数的用法

2.1函数结构

c 复制代码
void * memcpy ( void * destination, const void * source, size_t num ); 

2.2用法介绍

• 函数memcpy从source的位置开始向后复制num个字节的数据到destination指向的内存位置。

• 这个函数在遇到 '\0' 的时候并不会停下来。

• 如果source和destination有任何的重叠,复制的结果都是未定义的。

2.3代码实现

c 复制代码
#include <stdio.h>
#include <string.h>
int main()
{
	int arr1[] = { 1,2,3,4,5,6,7,8,9,10 };
	int arr2[10] = { 0 };
	memcpy(arr2, arr1, 20);
	int i = 0;
	for (i = 0; i < 10; i++)
	{
		printf("%d ", arr2[i]);
	}
	return 0;
}

2.4结果展示

3.memcpy函数的模拟实现

3.1代码实现

c 复制代码
//不建议这样写
void* my_memcpy(void* dest, const void* src, size_t num)
{
	void* ret = dest;
	assert(dest && src);
	while (num--)
	{
		//拷贝一个字节
		*(char*)dest = *(char*)src;
		++(char*)dest;
		++(char*)src;//存在一定的风险(有一些编译器不支持这种写法)
	}
	return ret;
}


//推荐写法
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;//转换后不能直接++,例如(char*)dest++
	}
	return ret;
}

int main()
{
	int arr[] = { 1,2,3,4,5,6,7,8,9,10 };
	//1 2 1 2 3 4 5 8 9 10
	//1 2 1 2 1 2 1 8 9 10
	memmove(arr + 2, arr, 20);
	int i = 0;
	for (i = 0; i < 10; i++)
	{
		printf("%d ", arr[i]);
	}

	return 0;
}
相关推荐
程序猿编码11 小时前
基于 Linux 内核模块的字符设备 FIFO 驱动设计与实现解析(C/C++代码实现)
linux·c语言·c++·内核模块·fifo·字符设备
纪元A梦12 小时前
贪心算法应用:K-Means++初始化详解
算法·贪心算法·kmeans
_不会dp不改名_12 小时前
leetcode_21 合并两个有序链表
算法·leetcode·链表
mark-puls13 小时前
C语言打印爱心
c语言·开发语言·算法
Python技术极客13 小时前
将 Python 应用打包成 exe 软件,仅需一行代码搞定!
算法
西阳未落13 小时前
C语言柔性数组详解与应用
c语言·开发语言·柔性数组
睡不醒的kun13 小时前
leetcode算法刷题的第三十四天
数据结构·c++·算法·leetcode·职场和发展·贪心算法·动态规划
吃着火锅x唱着歌13 小时前
LeetCode 978.最长湍流子数组
数据结构·算法·leetcode
我星期八休息13 小时前
深入理解跳表(Skip List):原理、实现与应用
开发语言·数据结构·人工智能·python·算法·list
lingran__13 小时前
速通ACM省铜第四天 赋源码(G-C-D, Unlucky!)
c++·算法