2024年C C++最新C语言——内存函数【memcpy,memmove,memset,memcmp】,C C++系列学习进阶视频

img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上C C++开发知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以戳这里获取

1,基本介绍

那么前面所提到的内存块重叠,例如:

arr1 [10] = {0,1,2,3,4,5,6,7,8,9};
我们希望把arr1中的2,3,4复制到3,4,5的位置,即变成:
arr1 [10] = {0,1,2,2,3,4,6,7,8,9}

面对内存有重叠时,我们不使用memcpy,而应该使用memmove👇🏻
在这里插入图片描述
🔍
●功能:
从source指向的位置开始向后复制num个字节的数据到destination指向的位置(是不是感觉和memcpy一样)
so👇🏻
●区别:
memmove函数可以用来处理源内存块和目标内存块重叠的情况

2,使用实例

假如我们还是要实现:

arr1 [10] = {0,1,2,3,4,5,6,7,8,9};
我们希望把arr1中的2,3,4复制到3,4,5的位置,即变成:
arr1 [10] = {0,1,2,2,3,4,6,7,8,9}

则👇🏻

#include<stdio.h>
#include<string.h>
int main()
{
	int arr1[] = { 0,1,2,3,4,5,6,7,8,9 };
	memmove(arr1+3, arr1+2,3\*sizeof(int)); 
	//从arr1+2的位置开始,往后面复制3个整数到arr1+3
	//打印arr1 观察结果
	for (int i = 0; i < 10; i++)
	{
		printf("%d ", arr1[i]);
	}
	return 0;
}

输出结果:
在这里插入图片描述

三,memset

1,基本介绍

在这里插入图片描述
🔍重点提取:
①所在头文件:string.h
②函数原型:
void * memset ( void * ptr, int value, size_t num );
ptr(要设置的内存),value(要赋的值),num(字节个数)
③函数功能:
将ptr指向的内存的前num个字节设置成value
④注意:
●这个函数是一个字节一个字节的改

2,使用实例

假如我们要把hello world的前5个字节改成x👇🏻

#include<stdio.h>
#include<string.h>
int main()
{
	char str[] = "hello world";
	memset(str, 'x', 5);
	printf(str);
	return 0;
}

输出结果:
在这里插入图片描述

假如我们要改整型数组:
arr[5] = {1,2,3,4,5};的前2个数字改成0👇🏻

#include<stdio.h>
#include<string.h>
int main()
{
	int arr[5] = { 1,2,3,4,5 };
	memset(arr, 0, 2\*sizeof(int));
	for (int i = 0; i < 5; i++)
	{
		printf("%d ", arr[i]);
	}
	return 0;
}

输出结果:
在这里插入图片描述

四,memcmp

1,基本介绍

在这里插入图片描述
●函数原型:int memcmp ( const void * ptr1, const void * ptr2, size_t num );
●功能:从ptr1和ptr2指向的位置开始,向后比num个字节
●比较方法及返回:(和strncmp类似)strncmp是一个一个字符的比,memcmp是一个一个字节的比(可以比较其他类型的数据,适用范围更广)
【如果有不知道如何比较的,可以看C语言——字符函数和字符串函数(二)里面对strcmp的比较的讲解

2,使用实例

我们来比较几个整型数组👇🏻
在这里插入图片描述

输出结果:
在这里插入图片描述

注意:
比较的时候num不要超过数组自身的大小
如:arr1和arr3比16个字节,这是有问题的。因为arr3只存放了3个整数,最多比12个字节


img
img

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**

需要这份系统化的资料的朋友,可以添加戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值