C语⾔内存函数

文章目录

1.memcpy使用和模拟实现

void * memcpy ( void * destination, const void * source, size_t num );

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

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

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

memcpy的使用:

c 复制代码
int main()
{
	int arr1[] = {1,2,3,4,5};
	int arr2[10] = { 0 };
	memcpy(arr2, arr1,  5* sizeof(int));//直接覆盖
	return 0;
}

memcpy的模拟实现:

c 复制代码
#include<assert.h>
void * my_memcpy(void* p1, void* p2, size_t count)
{
	assert(p1 && p2);
	void* ret = p1;
	while (count--)
	{
		*(char*)p1 = *(char*)p2;
		p1 = (char*)p1 + 1;
		p2 = (char*)p2 + 1;
	}
	return ret;
}
int main()
{
	int arr1[] = {1,2,3,4,5};
	int arr2[10] = { 0 };
	my_memcpy(arr2, arr1,  5* sizeof(int));//直接覆盖
	for (int i = 0; i < 6; i++)
	{
		printf("%d",arr2[i]);
  }
	return 0;
}

2.memmove使用和模拟实现

void * memmove ( void * destination, const void * source, size_t num );

• 和memcpy的差别就是memmove函数处理的源内存块和⽬标内存块是可以重叠的。

• 如果源空间和⽬标空间出现重叠,就得使⽤memmove函数处理。

memmove的使用:

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

memmove的模拟实现:

c 复制代码
#include<assert.h>
void* my_memcpy(void* p1, void* p2, size_t count)
{
	assert(p1 && p2);
	void* ret = p1;
	if (p1 < p2)
	{   //前-后
		while (count--)
		{
			*(char*)p1 = *(char*)p2;
			p1 = (char*)p1 + 1;
			p2 = (char*)p2 + 1;
		}
	}
	else
	{  //后-前
		while (count--)
					{
				*((char*)p1+count) = *((char*)p2 + count);
					}
	}
	return ret;
}
int main()
{
	int arr1[] = { 1,2,3,4,5,6,7};

	my_memcpy(arr1+2, arr1, 5 * sizeof(int));
	for (int i = 0; i < 7; i++)
	{
		printf("%d", arr1[i]);
	}
	return 0;
}

3. memset函数的使⽤

void * memset ( void * ptr, int value, size_t num );

memset是⽤来设置内存的,将内存中的值以字为单位设置成想要的内容。

c 复制代码
int main()
{
	char arr[] = "abcdef";
	memset(arr, 'x', 4);
	printf("%s",arr);
	return 0;
}

4.memcmp函数的使用

int memcmp ( const void * ptr1, const void * ptr2, size_t num );

• ⽐较从ptr1和ptr2指针指向的位置开始,向后的num个字节

c 复制代码
#include <string.h>
int main()
{
	char arr1[] = "abcdef";
	char arr2[] = "abb";
	int n = (arr1, arr2, 3 * sizeof(char));
	if (n > 0)
		printf("'%s' is greater than '%s'.\n", arr1, arr2);
	else if (n < 0)
		printf("'%s' is less than '%s'.\n", arr1, arr2);
	else
		printf("'%s' is the same as '%s'.\n", arr1, arr2);
	return 0;
}
相关推荐
[J] 一坚1 天前
嵌入式高手C
c语言·开发语言·stm32·单片机·mcu·51单片机·iot
qeen871 天前
【数据结构】树的基本概念及存储
c语言·数据结构·c++·学习·
pluviophile_s1 天前
第18讲:⾃定义类型:结构体
c语言·笔记
꧁细听勿语情꧂2 天前
向下调整算法,top - k 问题,链式结构二叉树,前中后序遍历
c语言·开发语言·数据结构·算法
SHARK_pssm2 天前
【数据结构——顺序表】
c语言·数据结构·经验分享·笔记
小柯博客2 天前
Amazon Kinesis Video Streams C WebRTC SDK 开发实战
c语言·开发语言·网络·stm32·嵌入式硬件·webrtc·yocto
上弦月-编程2 天前
C语言位运算:从入门到精通
运维·c语言·开发语言·vscode·算法·leetcode·极限编程
minglie12 天前
c语言面向对象的led
c语言·开发语言
钰珠AIOT2 天前
什么是句柄,有什么用?适用于什么场景?
c语言·c++
꧁细听勿语情꧂2 天前
用队列实现栈、用栈实现队列,树、二叉树、满二叉树、完全二叉树,堆、向下向上调整算法、出堆入堆、堆排序
c语言·开发语言·数据结构·算法