当前位置: 首页 > article >正文

C语⾔内存函数

文章目录

    • 1.memcpy使用和模拟实现
      • memcpy的使用:
      • memcpy的模拟实现:
    • 2.memmove使用和模拟实现
      • memmove的使用:
      • memmove的模拟实现:
    • 3. memset函数的使⽤
    • 4.memcmp函数的使用

1.memcpy使用和模拟实现

void * memcpy ( void * destination, const void * source, size_t num );
•函数memcpy从source的位置开始向后复制num个字节的数据到destination指向的内存置。
• 这个函数在遇到 ‘\0’ 的时候并不会停下来。
• 如果source和destination有任何的重叠,复制的结果都是未定义的。

memcpy的使用:

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

在这里插入图片描述

memcpy的模拟实现:

#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的使用:

#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的模拟实现:

在这里插入图片描述

#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是⽤来设置内存的,将内存中的值以字为单位设置成想要的内容。

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个字节

#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;
}

在这里插入图片描述


http://www.kler.cn/a/281050.html

相关文章:

  • 使用Masscan扫描器进行信息搜集
  • GCViT实战:使用GCViT实现图像分类任务(一)
  • 商城APP如何应对海量DDOS
  • 微服务CI/CD实践(二)服务器先决准备
  • Ruby应用部署的艺术:策略与实践
  • ETL数据集成丨实现SQLServer数据库的高效实时数据同步
  • 数据分页的艺术:SQL中的高效实现策略
  • Python是工程,不是艺术
  • 13-springcloud gateway集成nacos实现负载均衡
  • 【Java设计模式】Arrange/Act/Assert模式:增强测试的清晰度和简洁性
  • CSS3视图过渡动画
  • Rust: Filesystems and Command-Line Tools
  • 基于数据挖掘的心力衰竭疾病风险评估系统
  • 数据结构(邓俊辉)学习笔记】串 09——BM_BC算法:以终为始
  • ActiveMQ指南
  • window11彻底关闭Microsoft Defender
  • k8s Failed to delete cgroup paths
  • Debian常用包管理命令用法详解
  • [M链表] lc142. 环形链表 II(快慢指针+数学推导+基础题)
  • 网络安全新视角:人工智能在防御中的最新应用