第十七章:c语言内存函数

1. memcpy使⽤和模拟实现

2. memmove使⽤

3. memset函数的使⽤

4. memcmp函数的使⽤

              天行健  君子以自强不息

一、memcpy的使用和模拟实现

作用:

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

这个函数在遇到'\0'的时候不会停下来(该函数不检查源中是否有任何终止null字符------它总是精确地复制num个字节。)

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

1.1直接使用

c 复制代码
int main()
{
	int arr1[10] = { 0,1,2,3,4,5,6,7,8,9 };
	int len = sizeof(arr1) / sizeof(arr1[0]);
	int arr2[10] = { 0 };
	memcpy(arr2, arr1, sizeof(arr1));//这个是一个字节为单位的
	for (int i = 0; i < len; i++)
	{
		printf("%d ", arr2[i]);
	}
}

1.2 模拟实现

c 复制代码
#include<assert.h>
void* my_memcpy(void * pr2, const void* pr1, size_t count)
{
	void* ret = pr2;  //先把起始的地址储存起来
	assert(pr2 != NULL);
	assert(pr1 != NULL);
	while (count--)
	{
		//因为我们这里的单位是一个字节,所以我们要一个一个的访问比较好
		//这里是int类型的我们可以先转化为char类型的指针来进行操作
		*(char *)pr2 = *(char *)pr1;
		pr1 = (char*)pr1 + 1;
		pr2 = (char*)pr2 + 1;
	}
	return ret;
}

int main()
{
	   int arr1[10] = { 0,1,2,3,4,5,6,7,8,9 };
		int len = sizeof(arr1) / sizeof(arr1[0]);
		int arr2[10] = { 0 };
	int  * pr =	my_memcpy(arr2, arr1, sizeof(arr1)); //这里的是int类型的 所以接收也需要int * 类型的指针
	for (int i = 0; i < len; i++)
			{
				printf("%d ", *(pr+i));
			}
	return 0;
}

注意该函数不可以处理自己,会出现以下的错误

二、memmove使用

1.和memcpy 的差别就是memmove函数允许目标内存块的重叠

2.如果源空间和目标函数出现重叠,就要使用memmove函数处理

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

	return 0;
}

三、memset函数的使用

memset 函数是用来设置函数的,将内存储存的值以字节为单位设置成想要的内容

c 复制代码
#include<stdio.h>
#include<string.h>
//void* memset(void* ptr, int value, size_t num);
int main()
{
    char arr[10] = { "abcdefghj" };
    int num = sizeof(arr) / sizeof(arr[0]);
               //传进去的地址,设置的内容,设置字节的长度
   char * ret =  (char * )memset(&arr[1], 'x', 4);
   for (int i = 0; i < num; i++)
   {
       printf("%c ", arr[i]);
   }
    return 0;
}

四、memncmp函数的使用

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

返回值如下:

c 复制代码
int print(void)
{
	char arr3[20] = "abcd";
	char arr4[20] = "abcd";
	int num1 = memcmp(arr3, arr4, sizeof(arr3));
	return num1;

}
int main()
{

	char arr1[20] = "i am a student";
	char arr2[20] = "i am a stuDent";
	                 // arr1与arr2比较,比较的个数
	int num = memcmp(arr1, arr2, sizeof(arr1));
	printf("%d\n", num);
	if (num > 0)
	{
		printf("arr1>arr2\n");
	}
	else if (num < 0)
	{
		printf("arr1<arr2\n");

	}
	else
	{
		printf("arr1=arr2\n");
	}

	int ret = print();
	printf("%d\n",ret);

	return 0;
}
相关推荐
童先生21 分钟前
Go 项目中实现类似 Java Shiro 的权限控制中间件?
开发语言·go
lulu_gh_yu22 分钟前
数据结构之排序补充
c语言·开发语言·数据结构·c++·学习·算法·排序算法
Re.不晚1 小时前
Java入门15——抽象类
java·开发语言·学习·算法·intellij-idea
老秦包你会1 小时前
Qt第三课 ----------容器类控件
开发语言·qt
凤枭香1 小时前
Python OpenCV 傅里叶变换
开发语言·图像处理·python·opencv
ULTRA??1 小时前
C加加中的结构化绑定(解包,折叠展开)
开发语言·c++
远望清一色1 小时前
基于MATLAB的实现垃圾分类Matlab源码
开发语言·matlab
confiself1 小时前
大模型系列——LLAMA-O1 复刻代码解读
java·开发语言
XiaoLeisj2 小时前
【JavaEE初阶 — 多线程】Thread类的方法&线程生命周期
java·开发语言·java-ee
杜杜的man2 小时前
【go从零单排】go中的结构体struct和method
开发语言·后端·golang