日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學(xué)無先后,達(dá)者為師

網(wǎng)站首頁 編程語言 正文

C++中memcpy函數(shù)的使用以及模擬實(shí)現(xiàn)_C 語言

作者:~小明學(xué)編程~ ? 更新時(shí)間: 2022-09-10 編程語言

前言

memcpy函數(shù)如何使用,以及如何實(shí)現(xiàn)我們自己的my_memcpy在這里給大家詳細(xì)介紹。

一、什么是memcpy

memcpy是c和c++使用的內(nèi)存拷貝函數(shù),memcpy函數(shù)的功能是從源src所指的內(nèi)存地址的起始位置開始拷貝n個(gè)字節(jié)到目標(biāo)dest所指的內(nèi)存地址的起始位置中。

二、memcpy與strcpy的區(qū)別

1.復(fù)制的內(nèi)容不同。strcpy只能復(fù)制字符串,而memcpy可以復(fù)制任意內(nèi)容,例如字符數(shù)組、整型、結(jié)構(gòu)體、類等。

2.復(fù)制的方法不同。strcpy不需要指定長度,它遇到被復(fù)制字符的串結(jié)束符"\0"才結(jié)束,所以容易溢出。memcpy則是根據(jù)其第3個(gè)參數(shù)決定復(fù)制的長度。

3.用途不同。通常在復(fù)制字符串時(shí)用strcpy,而需要復(fù)制其他類型數(shù)據(jù)時(shí)則一般用memcpy

1.strcpy

int main()
{
	char arr1[] = "abcdef";
	char arr2[20] = { 0 };
	strcpy(arr2, arr1);
	printf("%s", arr2);
	return 0;
}

這里我們可以看到字符串a(chǎn)rr1已經(jīng)被拷貝

我們?cè)倏匆幌孪旅娴拇a

int main()
{
	int arr1[] = { 1,2,3,4,5 };
	int arr2[5] = { 0 };
	printf("%s", arr2);
	return 0;
}

這時(shí)我們發(fā)現(xiàn)arr2就不能正常的拷貝了,因?yàn)閟trcpy只能拷貝字符串,int類型的數(shù)組或者結(jié)構(gòu)體都是不能拷貝的,因?yàn)閟trcpy比較依賴’\0’通過檢測(cè)‘\0’來實(shí)現(xiàn)函數(shù)的,這時(shí)就需要我們的memcpy函數(shù)了。

2.memcpy

在這里插入圖片描述

我們這里簡(jiǎn)單介紹一下函數(shù)的使用,函數(shù)的三個(gè)參數(shù)分別是dest(要復(fù)制的目的地),str(原目標(biāo)),count(要復(fù)制內(nèi)容的大小)。

struct S
{
	char name[10];
	int age;
};
int main()
{
	struct S arr1[] = {{"ajd",20},{"qwe",18}};
	struct S arr2[3] = { 0 };
	memcpy(arr2, arr1, sizeof(arr1));
	return 0;
}

這里我們通過memcpy函數(shù)成功復(fù)制了結(jié)構(gòu)體arr1。

在這里插入圖片描述

三、模擬實(shí)現(xiàn)memcpy

void* my_memcpy(void* dest, const void* src, size_t num)
{
	assert(dest && src);
	void* ret = dest;
	while (num--)
	{
		*(char*)dest = *(char*)src;
		++(char*)dest;
		++(char*)src;
	}
	return ret;

}
struct S
{
	char name[10];
	int age;
};
int main()
{
	struct S arr1[] = {{"ajd",20},{"qwe",18}};
	struct S arr2[3] = { 0 };
	my_memcpy(arr2, arr1, sizeof(arr1));
	return 0;
}

這里我們模擬實(shí)現(xiàn)了memcpy函數(shù)。

在這里插入圖片描述

總結(jié)

原文鏈接:https://blog.csdn.net/m0_56911284/article/details/125831972

欄目分類
最近更新