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;
}
相关推荐
xie_pin_an1 小时前
深入浅出 C 语言数据结构:从线性表到二叉树的实战指南
c语言·数据结构·图论
总爱写点小BUG5 小时前
打印不同的三角形(C语言)
java·c语言·算法
xie_pin_an9 小时前
C 语言排序算法全解析:从原理到实战,附性能对比
c语言·算法·排序算法
再睡一夏就好9 小时前
深入解析Linux页表:从虚拟地址到物理内存的映射艺术
linux·运维·服务器·c语言·c++·页表·缺页异常
LinHenrY122710 小时前
初识C语言(编译和链接)
c语言·开发语言·蓝桥杯
l1t10 小时前
利用小米mimo为精确覆盖矩形问题C程序添加打乱函数求出更大的解
c语言·开发语言·javascript·人工智能·算法
松涛和鸣11 小时前
34、 Linux IPC进程间通信:无名管道(Pipe) 和有名管道(FIFO)
linux·服务器·c语言·网络·数据结构·数据库
秦苒&11 小时前
【C语言】详解数据类型和变量(一):数据类型介绍、 signed和unsigned、数据类型的取值范围、变量、强制类型转换
c语言·开发语言·c++·c#
LinHenrY122711 小时前
初识C语言(文件操作)
c语言·windows·microsoft
智者知已应修善业12 小时前
【删除有序数组中的重复项 II之O(N)算法】2024-1-31
c语言·c++·经验分享·笔记·算法