memcpy的使⽤和模拟实现

目录

一:memcpy的使⽤

memcpy的使⽤的代码

二:memcpy函数的模拟实现:

memcpy和strcpy的区别

用途:

安全性:

数据类型:

性能:

在字符串中的用法示例:

memcpy:

strcpy

一:memcpy的使⽤

这是memcpy在库里的定义,具体可在cplusplus.com查看

void * memcpy ( void * destination, const void * source, size_t num )

•num单位是字节,下面的模拟实现需要强制类型转换

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

• 这个函数在遇到 '\0' 的时候并不会停下来。

• 如果source和destination有任何的重叠,复制的结果都是未定义的。对于重叠的内存,交给memmove来处理。(下期会有)

memcpy的使⽤的代码

#include <stdio.h> 
#include <string.h>
int main()
{    int arr1[] = { 1,2,3,4,5,6,7,8,9,10 };    int arr2[10] = { 0 };   memcpy(arr2, arr1, 20);    int i = 0;    for (i = 0; i < 10; i++)  {      printf("%d ", arr2[i]);//结果是1 2 3 4 5 6 7 8 9 10   }   return 0; 
}

二:memcpy函数的模拟实现:

(模拟实现)就要严格按照库里所规定的

void和void*的用法已经发布

#include<stdio.h>
#include<assert.h>
void * my_memcpy ( void * dst, const void * src, size_t count)
{   void * ret = dst;    assert(dst);    assert(src);    while (count--) {            *(char *)dst = *(char *)src;//强制类型转换            dst = (char *)dst + 1;//强制类型转换           src = (char *)src + 1;//强制类型转换   }return(ret); 
}int main()
{	int arr1[]={1,2,3,4,5,6,7};int arr2[10]={0};void*p=my_memcpy(arr2,arr1,20);for(int i=0;i<10;i++){printf("%d ",*((int*)p+i));//强制类型转换}return 0;} 

memcpy和strcpy的区别

C语言中memcpy和strcpy是两个常用的字符串和内存操作函数,但它们在用途和行为上有明显的区别。

memcpy和strcpy都可以用在字符串,memcpy和strncpy在字符串中的使用几乎完全等价。

用途:

memcpy:是一个通用的内存复制函数,它用于从源地址(source)开始拷贝n个字节到目标地址(destination)。源地址和目标地址可以是任何类型的内存区域,但必须确保目标内存区域有足够的空间来容纳源内存区域的内容。
strcpy:是一个专门用于复制字符串的函数,它从源字符串(source string)的起始位置开始,逐个字符地复制到目标字符串(destination string)中,直到遇到源字符串中的空字符(null character, '\0')为止。这意味着strcpy会自动处理字符串的终止符。

安全性:

memcpy:不检查目标内存区域是否足够大以容纳源内存区域的内容。如果目标内存区域小于源内存区域,那么memcpy将会导致缓冲区溢出(buffer overflow),这是一个严重的安全漏洞,可能导致程序崩溃或被恶意利用。
strcpy:同样存在缓冲区溢出的风险,尤其是当目标字符串数组的大小不足以容纳源字符串(包括终止符)时。然而,由于strcpy是专门为字符串设计的,所以它在某些情况下可能更容易被识别和避免这种风险(例如,使用更安全的替代品如strncpy)。

数据类型:

memcpy:可以复制任何类型的内存区域,包括字符串、整数、浮点数等。它只关心字节的数量和起始地址。
strcpy:只能用于复制字符串,即字符数组。

性能:

在大多数情况下,由于memcpy不需要检查空字符,所以它可能比strcpy稍微快一些。然而,这种差异通常很小,而且在许多现代编译器和优化器的优化下可能变得不明显。

在字符串中的用法示例:

memcpy:

#include<stdio.h>
#include<string.h>
int main()
{char arr3[]="abcdef";char arr4[20];memcpy(arr4,arr3,4);printf("%s\n",arr4);//结果:abcd
}

strcpy:

#include<stdio.h>
int main()
{char arr5[]="abcdef";char arr6[20];strncpy(arr6,arr5,4);//strcpy(arr6,arr5);,不可以确切的复制字符串,只能全部复制进去printf("%s\n",arr6);//结果也是abcd}


注意:在使用memcpy和strcpy时,都应该确保目标内存区域有足够的空间来容纳源内存区域的内容,以避免缓冲区溢出。在实际编程中,更推荐使用更安全的替代品,如strncpy和strncpy_s(如果编译器支持)。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Ajax面试题精选及参考答案(3万字长文)

目录 什么是Ajax,它的核心原理是什么? Ajax应用程序的优势有哪些? Ajax最大的特点是什么?

Science 基于尖峰时序编码的模拟神经触觉系统,可实现动态对象分类

快速处理和有效利用手与物体交互过程中产生的动态触觉信号&#xff08;例如触摸和抓握&#xff09;对于触觉探索和灵巧的物体操作至关重要。将电子皮肤&#xff08;e-skins&#xff09;推进到模仿自然触觉的水平&#xff0c;是恢复截肢者和瘫痪患者丧失的功能的可行解决方案&am…

实现地图上展示坐标时,不要全部展示、只展示几个距离相对较大marker点位,随着地图放大再全部展示出来。

比例尺级别地面分辨率 &#xff08;米/像素&#xff09;比例尺0156543.031&#xff1a;591658700.82178271.5151&#xff1a;295829350.4239135.75751&#xff1a;147914675.2319567.878751&#xff1a;73957337.649783.9393751&#xff1a;36978668.854891.9696881&#xff1a…

电机控制系列模块解析(22)—— 零矢量刹车

一、零矢量刹车 基本概念 逆变器通常采用三相桥式结构&#xff0c;包含六个功率开关元件&#xff08;如IGBT或MOSFET&#xff09;&#xff0c;分为上桥臂和下桥臂。每个桥臂由两个反并联的开关元件组成&#xff0c;上桥臂和下桥臂对应于电机三相绕组的正负端。正常工作时&…

mongodb在游戏开发领域的优势

1、分布式id 游戏服务器里的大部分数据都是要求全局唯一的&#xff0c;例如玩家id&#xff0c;道具id。之所以有这种要求&#xff0c;是因为运营业务上需要进行合服操作&#xff0c;保证不同服的数据在进行合服之后&#xff0c;也能保证id不冲突。如果采用关系型数据库&#x…

【C++题解】1699 - 输出是2的倍数,但非3的倍数的数

问题&#xff1a;1699 - 输出是2的倍数&#xff0c;但非3的倍数的数 类型&#xff1a;循环 题目描述&#xff1a; 请从键盘读入一个整数 n&#xff0c;输出 1∼n 中所有是 2 的倍数&#xff0c;但非 3 的倍数的数&#xff0c;每行 1个。 比如&#xff0c;读入一个整数10 &…

Spring AI实战之二:Chat API基础知识大串讲(重要)

欢迎访问我的GitHub 这里分类和汇总了欣宸的全部原创(含配套源码)&#xff1a;https://github.com/zq2599/blog_demos Spring AI实战全系列链接 Spring AI实战之一&#xff1a;快速体验(OpenAI)Spring AI实战之二&#xff1a;Chat API基础知识大串讲(重要)SpringAIOllama三部曲…

Linux:进程地址空间、进程控制(一.进程创建、进程终止、进程等待)

上次介绍了环境变量&#xff1a;Linux&#xff1a;进程概念&#xff08;四.main函数的参数、环境变量及其相关操作&#xff09; 文章目录 1.程序地址空间知识点总结上述空间排布结构是在内存吗&#xff1f;&#xff08;进程地址空间引入&#xff09; 2.进程地址空间明确几个点进…

NDIS小端口驱动开发(三)

微型端口驱动程序处理来自过度驱动程序的发送请求&#xff0c;并发出接收指示。 在单个函数调用中&#xff0c;NDIS 微型端口驱动程序可以指示具有多个接收 NET_BUFFER_LIST 结构的链接列表。 微型端口驱动程序可以处理对每个NET_BUFFER_LIST结构上具有多个 NET_BUFFER 结构的多…

JAVA -- > 初识JAVA

初始JAVA 第一个JAVA程序详解 public class Main {public static void main(String[] args) {System.out.println("Hello world");} }1.public class Main: 类型,作为被public修饰的类,必须与文件名一致 2.public static 是JAVA中main函数准写法,记住该格式即可 …

python皮卡丘动画代码

在Python中&#xff0c;我们可以使用多种方法来创建皮卡丘的动画&#xff0c;例如使用matplotlib库。 解决方案1&#xff1a;使用matplotlib库 以下是一个使用matplotlib库创建皮卡丘动画的例子&#xff1a; import matplotlib.pyplot as plt import matplotlib.animation …

Slash后台管理系统代码阅读笔记 如何实现环形统计图表卡片?

目前&#xff0c;工作台界面的上半部分已经基本梳理完毕了。 接下来&#xff0c;我们看看这个环形图卡片是怎么实现的&#xff1f; 具体代码如下&#xff1a; {/*图表卡片*/} <Row gutter{[16, 16]} className"mt-4" justify"center">{/*环形图表…

U盘引导盘制作Rufus v4.5.2180

软件介绍 Rufus小巧实用开源免费的U盘系统启动盘制作工具和格式化U盘的小工具&#xff0c;它可以快速将ISO镜像文件制作成可引导的USB启动安装盘&#xff0c;支持Windows或Linux启动&#xff0c;堪称写入镜像速度最快的U盘系统制作工具。 软件截图 更新日志 github.com/pbat…

嵌入式全栈开发学习笔记---C语言笔试复习大全24

目录 内存管理 内存分配 堆和栈的区别&#xff1f;&#xff08;面试重点&#xff09; 申请内存的函数 malloc realloc free gcc工具链 编译的过程&#xff08;面试重点&#xff09; 第一步&#xff0c;预处理&#xff1a; 第二步&#xff0c;编译&#xff1a; 第三…

【Spring Boot】使用 Redis + Cafeine 实现二级缓存

使用 Redis Caffeine 实现二级缓存可以有效提升应用的性能和缓存的命中率。Caffeine 是一个高效的 Java 本地缓存库&#xff0c;而 Redis 是一个分布式缓存解决方案。通过将两者结合&#xff0c;Caffeine 作为一级缓存用于快速访问常用数据&#xff0c;Redis 作为二级缓存用于…

解决LabVIEW通过OPC Server读取PLC地址时的错误180121602

在使用LabVIEW通过OPC Server读取PLC地址时&#xff0c;若遇到错误代码180121602&#xff0c;建议检查网络连接、OPC Server和PLC配置、用户权限及LabVIEW设置。确保网络畅通&#xff0c;正确配置OPC变量&#xff0c;取消缓冲设置以实时读取数据&#xff0c;并使用诊断工具验证…

簡述vue常用指令

Vue.js 提供了许多内置指令&#xff0c;这些指令用于在模板中添加特殊功能。以下是一些 Vue 的常用内置指令的简要说明&#xff1a; v-text&#xff1a; 更新元素的 textContent。示例&#xff1a;<span v-text"message"></span> v-html&#xff1a; 更…

2 使用香橙派AIpro报错 No module named ‘acllite utils‘

当使用jupyter运行香橙派的notebooks下面的案例的时候启动使用jupyter lab 然后自动跳转到jupyter页面。如下图: 这是自动跳转过来的。然后运行下面的包的导入后报错: 报错为No module named ‘acllite utils’,那么我们打开notebooks文件夹下面的start_notebooks.sh文件:…

【C++练级之路】【Lv.21】C++11——列表初始化和声明

快乐的流畅&#xff1a;个人主页 个人专栏&#xff1a;《算法神殿》《数据结构世界》《进击的C》 远方有一堆篝火&#xff0c;在为久候之人燃烧&#xff01; 文章目录 引言一、列表初始化1.1 内置类型1.2 结构体或类1.3 容器 二、声明2.1 auto2.2 decltype2.3 nullptr 三、STL的…

A*算法搜索的路径是最优的么?

A * 算法&#xff08;A* Search Algorithm&#xff09;是一种启发式搜索算法&#xff0c;它旨在找到从起点到终点的最短路径。在满足以下条件时&#xff0c;A*算法能够保证找到最优路径&#xff1a; 启发式函数的一致性&#xff08;Consistency&#xff09;或可采纳性&#xf…