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

1. memcpy使⽤和模拟实现

2. memmove使⽤

3. memset函数的使⽤

4. memcmp函数的使⽤

              天行健  君子以自强不息

一、memcpy的使用和模拟实现
在这里插入图片描述

作用:
1.
函数memcpy从source的位置向后复制num个字节的数据到destination指向的内存位置。
2.
这个函数在遇到‘\0’的时候不会停下来(该函数不检查源中是否有任何终止null字符——它总是精确地复制num个字节。)
3.如果source和destination有任何的重叠,复制的结果都是未定义的。

1.1直接使用

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

#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函数处理

#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 函数是用来设置函数的,将内存储存的值以字节为单位设置成想要的内容

#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个字节
返回值如下:
在这里插入图片描述

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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/1551001.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

用Python实现运筹学——Day 7: 线性规划的对偶理论

一、学习内容 1. 对偶问题的概念与对偶定理 线性规划的对偶理论是一种非常重要的理论&#xff0c;能揭示线性规划问题中的原问题和对偶问题之间的关系。给定一个线性规划的原问题&#xff0c;可以通过构造一个相关的对偶问题来帮助理解原问题的解&#xff0c;或者直接求解对偶…

详细分析Java中的StopWatch基本知识(附Demo)

目录 前言1. 基本知识2. Demo 前言 对于Java的基本知识推荐阅读&#xff1a; java框架 零基础从入门到精通的学习路线 附开源项目面经等&#xff08;超全&#xff09;【Java项目】实战CRUD的功能整理&#xff08;持续更新&#xff09; 1. 基本知识 StopWatch 是 Spring Fra…

【TabBar嵌套Navigation案例-新特性页面-背景图片 Objective-C语言】

一、接下来,我们来做这个背景图片的这个功能啊 1.首先呢,我们command + R跑一下,现在都是有一堆颜色, 大体的这个框架啊,我们都已经搭好了, 接下来,我们把这几个颜色啊,CollectionView的背景图片,给它设置一下, 首先呢,这个设置啊,我们这么着来做,我们呢,肯定…

解决:使用layui.treeTable.updateNode,更新表格数据后,done里面的事件丢失问题

1. 背景 在给树形表格添加行点击事件&#xff0c;并且只更新当前行数据。 treeTable.updateNode("SpeProjListId", result.LAY_DATA_INDEX, result);更新数据后&#xff0c;点击事件失效。 1. 给字段绑定事件&#xff1a; class"link_a link_style" , {…

草莓病虫害数据集1000张分5类 草莓植株黑斑病、草莓灰霉菌病、正常草莓、草莓粉霉菌病、草莓橡胶病

草莓病虫害数据集 1000张 分5类 草莓植株黑斑病、草莓灰霉菌病、正常草莓、草莓粉霉菌病、草莓橡胶病 草莓病虫害数据集介绍 名称 草莓病虫害数据集 规模 图像数量&#xff1a;1000张高质量图像类别数量&#xff1a;5类 草莓植株黑斑病 (Black Spot Disease)草莓灰霉菌病 (…

【Python】Curdling:Python 包管理的高效工具

Curdling 是一个轻量级的 Python 包管理工具&#xff0c;旨在加速 Python 包的安装和管理流程。与传统的包管理工具&#xff08;如 pip&#xff09;相比&#xff0c;Curdling 更加注重性能优化和效率&#xff0c;特别是在处理大规模依赖项和项目构建时表现优异。它通过并行化的…

360° 镜头检测铝件内壁划痕与杂质:保障铝件内孔制造质量的精准方案

在铝件内孔制造的过程中&#xff0c;内壁的质量把控是至关重要的环节。制造过程中产生的碎屑残留以及划痕等问题&#xff0c;不仅会影响铝件的外观&#xff0c;更可能对其性能和使用寿命造成严重的损害。为了精准检测这些问题&#xff0c;我们提出了一套基于 360 镜头的检测方案…

3. 将GitHub上的开源项目导入(clone)到本地pycharm上——深度学习·科研实践·从0到1

目录 1. 在github上搜项目 (以OpenOcc为例&#xff09; 2. 转移到码云Gitee上 3. 下载整个项目到本地 4. 在pycharm中打开项目 1. 在github上搜项目 (以OpenOcc为例&#xff09; 把链接复制下来&#xff0c;转移到国内Gitee上&#xff0c;会更稳定 2. 转移到码云Gitee上 &…

深度学习-11

线性层及其它层介绍 归一化层 在深度学习中&#xff0c;归一化层&#xff08;Normalization Layers&#xff09;是神经网络中非常重要的一部分&#xff0c;它们有助于在训练过程中稳定网络&#xff0c;加速收敛&#xff0c;以及提高模型的泛化能力。以下是PyTorch框架中一些常…

6.1 微服务 服务发现 架构模式分类 应用实践

微服务 服务发现 架构模式分类 应用实践 目录概述需求&#xff1a; 设计思路实现思路分析1.类型-客户端发现2.类型-服务端服务发现3.工具-Eureka4.工具-Consul5.工具-zookper服务发现的挑战服务发现的最佳实践 参考资料和推荐阅读 Survive by day and develop by night. talk …

谷歌Gemini 1.5 AI模型升级:成本更低、性能更强、响应更快

AITOP100获悉&#xff0c;9月24日&#xff0c;谷歌谷歌Gemini 1.5 AI模型升级&#xff1a;成本更低、性能更强、响应更快对其旗下Gemini 1.5 AI模型进行了升级&#xff0c;推出了Gemini-1.5-Pro-002和Gemini-1.5-Flash-002两款新模型。这两款模型在成本、性能和响应速度方面均有…

在线PDF怎么转换成JPG图片?分享14种转换操作!

作为一名社畜&#xff0c;俺也经常要将PDF转换为图片格式&#xff01; 如何进行快速转换&#xff0c;包括电脑端、在线端和手机端&#xff0c;今天俺就测评了50款工具&#xff0c;给你得出了下面这些渠道&#xff0c;不少也是免费的&#xff0c;相信对你有帮助哦&#xff01; …

Spring - @Import注解

文章目录 基本用法源码分析ConfigurationClassPostProcessorConfigurationClass SourceClassgetImportsprocessImports处理 ImportSelectorImportSelector 接口DeferredImportSelector 处理 ImportBeanDefinitionRegistrarImportBeanDefinitionRegistrar 接口 处理Configuratio…

2-3树(2-3 Tree):原理、常见算法及其应用

目录 引言 2-3树的基本概念 常见算法 查找节点 插入节点 删除节点 2-3树的应用场景 1. 文件系统目录管理 应用原理 场景描述 2. 字典编码 应用原理 场景描述 总结 优势对比 自平衡特性 灵活的节点结构 高效的操作性能 简单的实现 广泛的应用场景 数据一致…

遥感图像分割

遥感图像分割是一种应用于遥感图像的计算机视觉技术&#xff0c;用于将图像划分为不同的区域&#xff0c;每个区域代表地表的不同特征&#xff0c;如水体、森林、城市区域等。这种分割帮助我们更好地理解和分析地球表面的变化&#xff0c;对于环境监测、城市规划、农业、灾害管…

AR技术在电商行业的应用及优势有哪些?

AR&#xff08;增强现实&#xff09;技术在电商行业的应用广泛且深入&#xff0c;为消费者带来了全新的购物体验&#xff0c;同时也为商家带来了诸多优势。以下是AR技术在电商行业的主要应用场景及其优势&#xff1a; 一、应用场景 1、虚拟商品展示与试用 家具AR摆放&#x…

济南站活动回顾|IvorySQL中的Oracle XML函数使用示例及技术实现原理

近日&#xff0c;由中国开源软件推进联盟PG分会 & 齐鲁软件园联合发起的“PostgreSQL技术峰会济南站”在齐鲁开源社举办。瀚高股份IvorySQL作为合作伙伴受邀参加此次活动。 瀚高股份IvorySQL技术工程师 向逍 带来「IvorySQL中的Oracle XML函数兼容」的议题分享。在演讲中&a…

前端vue-form表单的验证

form表单验证的完整步骤

二叉树的中序遍历(java)

概述 关于二叉树&#xff0c;我们都不陌生&#xff0c;许多基于递归的问题发起点都是一个二叉树的root节点。对于各种二叉树的问题&#xff0c;我们也是通过dfs进行求解。例如求二叉树的深度、最近公共祖先等 算法分析 关于二叉树的中序遍历&#xff0c;我们都知道应该先访…

【C++单调队列】1438. 绝对差不超过限制的最长连续子数组|1672

本文时间知识点 C队列、双向队列 LeetCode1438. 绝对差不超过限制的最长连续子数组 给你一个整数数组 nums &#xff0c;和一个表示限制的整数 limit&#xff0c;请你返回最长连续子数组的长度&#xff0c;该子数组中的任意两个元素之间的绝对差必须小于或者等于 limit 。 如…