轻松拿捏C语言——【内存函数】

🥰欢迎关注 轻松拿捏C语言系列,来和 小哇 一起进步!

🎉创作不易,请多多支持🎉

🌈感谢大家的阅读、点赞、收藏和关注💕

🌹如有问题,欢迎指正~~


目录👑

💕1. memcpy()💕

函数原型❤️

示例❤️

 函数模拟❤️

🌟🌟2. memmove()

函数原型🌙

示例🌙

函数模拟实现🌙

💕3. memset()💕

函数原型❤️

示例❤️

🌟🌟4. memcmp()

函数原型🌙

示例🌙


C语言中的内存操作函数:memcpy, memmove, memset, memcmp

在C语言中,我们经常需要对内存块进行各种操作,比如复制、移动、设置值以及比较。C标准库提供了四个非常有用的函数来处理这些操作:memcpy, memmove, memset, memcmp

下面我将逐一介绍这些函数及其用法。

💕1. memcpy()💕

用于从源内存块复制指定数量的字节到目标内存块。这个函数不检查源内存和目标内存是否重叠,因此如果重叠,它可能会导致未定义的行为。

函数原型❤️

void *memcpy(void *dest, const void *src, size_t n);
  • dest:指向目标内存块的指针。
  • src:指向源内存块的指针。
  • n:要复制的字节数。
  • 这个函数在遇到 '\0' 的时候并不会停下来。

示例❤️

#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]);}return 0;
}

打印 1 2 3 4 5 0 0 0 0 0

#include <stdio.h>  
#include <string.h>  
int main() {  char src[] = "Hello, World!";  char dest[20];  memcpy(dest, src, 13); // 复制前13个字节(包括空字符'\0')  printf("%s\n", src);  printf("%s\n", dest);  return 0;  
}

 函数模拟❤️

法一:

//法一
void* my_memcpy1(void* dest,const void* source, size_t num)
{void* ret = dest;while (num--){//*((char*)dest)++ = *((char*)source)++;*(char*)dest = *(char*)source;dest = (char*)dest + 1;source = (char*)source + 1;}return ret;
}int main()
{int arr1[] = { 1,2,3,4,5,6,7,8 };int arr2[5] = { 0 };//memcpy(arr2, arr1 + 2, 17);my_memcpy1(arr2, arr1 + 2, 17);int i;for (i = 0; i < 5; i++)printf("%d ", arr1[i]);return 0;
}

法二:

//法二
void* my_memcpy2(void* dest, void* src, size_t num)
{char* d = (char*)dest;char* s = (char*)src;while (num--){*d++ = *s++;}return dest;
}
int main()
{int arr1[] = { 1,2,3,4,5,6,7,8 };int arr2[5] = { 0 };//memcpy(arr2, arr1 + 2, 17);my_memcpy2(arr2, arr1 + 2, 17);int i;for (i = 0; i < 5; i++)printf("%d ", arr2[i]);return 0;
}

 打印3 4 5 6 7

🌟🌟2. memmove()

memmove() 函数与 memcpy() 类似,但它可以正确处理源内存和目标内存重叠的情况。

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

memmove也具有memcpy的功能

函数原型🌙

void *memmove(void *dest, const void *src, size_t n);

参数与 memcpy() 相同。

示例🌙

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

打印1 2 1 2 3 4 5 8 9 10

#include <stdio.h>  
#include <string.h>  int main() {char str[] = "Hello, World!";memmove(str + 6, str, 5); printf("%s\n", str);return 0;
}

 打印Hello,Hellod!

函数模拟实现🌙

void* my_memmove(void* dest, void* src, size_t num)
{char* d = (char*)dest;char* s = (char*)src;if (dest < src){while (num--)*d++ = *s++;}else{while (num--)*(d + num) = *(s + num);}return dest;
}
int main()
{int arr[10] = { 1,2,3,4,5,6,7,8,9,10 };//memmove(arr, arr + 2, 12);/*char str[] = "Hello, World!";memmove(str + 6, str, 5);printf("%s\n",str);*/my_memmove(arr, arr + 2, 12);int i = 0;for (i; i < 10; i++)printf("%d ", arr[i]);return 0;
}

打印3 4 5 4 5 6 7 8 9 10

💕3. memset()💕

memset() 函数用于将指定内存块的前n个字节设置为某个给定的值(一个无符号字符)。

函数原型❤️

void * memset ( void * ptr, int value, size_t num );

memset是来设置内存的,将内存中的值以字节为单位设置成想要的内容 。

从地址ptr开始往后的num个字节都设置成value

示例❤️

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

输出:xxxxxxworld

#include <stdio.h>  
#include <string.h>  int main() {char str[50]={0};memset(str, 'A', 10); // 将str的前10个字节设置为'A'  printf("%s\n", str);   return 0;
}

  输出 :AAAAAAAAAA

注意:memset() 只会设置到字符串的指定长度,并不会自动添加字符串结束符 '\0'。

🌟🌟4. memcmp()

memcmp() 函数用于比较两个内存块的内容。

函数原型🌙

int memcmp ( const void * ptr1, const void * ptr2, size_t num );

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

如果ptr1和 ptr2 的前n个字节完全相同,则返回 0;

如果 ptr1小于 ptr2 ,则返回一个小于 0 的值;

如果ptr1大于  ptr2 ,则返回一个大于 0 的值。

示例🌙

#include <stdio.h>
#include <string.h>
int main()
{int arr1[] = { 1,2,3,4,5 };int arr2[] = { 1,2,3,6,5 };int ret = memcmp(arr1, arr2,13);printf("%d", ret);//-1return 0;
}

打印-1

#include <stdio.h>  
#include <string.h>  int main()
{char str1[] = "Hello";char str2[] = "World";int result = memcmp(str1, str2, 5); // 比较两个字符串的前5个字节  if (result < 0) {printf("str1 is less than str2\n");}else if (result > 0) {printf("str1 is greater than str2\n");}else {printf("str1 is equal to str2\n");}return 0;
}

打印:str1 is less than str2 


 🎉🎉🎉本文内容结束啦,希望各位大佬多多指教

🌹🌹感谢大家三连支持

💕敬请期待~~

 

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

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

相关文章

JVM学习-类加载过程(一)

概述 在Java中数据类型分为基本数据类型和引用数据类型&#xff0c;基本数据类型由虚拟机预先定义&#xff0c;引用数据类型则需要进行类的加载按Java虚拟机规范&#xff0c;从class文件加载到内存中的类&#xff0c;到类卸载出内存为止&#xff0c;它的整个生命周期包含以下7…

测试工具fio

一、安装部署 fio是一款优秀的磁盘IO测试工具&#xff0c;在Linux中比较常用于测试磁盘IO 其下载地址&#xff1a;https://brick.kernel.dk/snaps/fio-2.1.10.tar.gz 或者登录其官网&#xff1a;http://freshmeat.sourceforge.net/projects/fio/ 进行下载。 tar -zxvf fio-…

【redis】宝塔,线上环境报Redis error: ERR unknown command del 错误

两种方式&#xff1a; 1.打开宝塔上的redis&#xff0c;通过配置文件修改权限&#xff0c;注释&#xff1a;#rename-command DEL “” 2.打开服务器&#xff0c;宝塔中默认redis安装位置是&#xff1a;cd /www/server/redis 找到redis.conf,拉到最后&#xff0c;注释#rename-co…

Flutter 验证码输入框

前言&#xff1a; 验证码输入框很常见&#xff1a;处理不好 bug也会比较多 想实现方法很多&#xff0c;这里列举一种完美方式&#xff0c;完美兼容 软键盘粘贴方式 效果如下&#xff1a; 之前使用 uniapp 的方式实现过一次 两种方式&#xff08;原理相同&#xff09;&#xff1…

二叉树链式结构的前序、中序、后序、层序遍历

文章目录 一、二叉树创建二、前序遍历概念以及解释代码 三、中序遍历概念及解释代码 四、后序遍历概念及解释代码 五、层序遍历概念及解释代码 一、二叉树创建 &mesp; 实现二叉树的遍历&#xff0c;我们要先手搓出一个二叉树&#xff0c;在次基础上实现二叉树的前序、中序…

【RLHF个人笔记】RLHF:Reinforcement Learning from Human Feedback具体过程

【RLHF个人笔记】RLHF:Reinforcement Learning from Human Feedback具体过程 RLHF训练的三个步骤步骤1&#xff1a;收集数据与有监督训练策略步骤2&#xff1a;收集数据训练奖励模型步骤3&#xff1a;结合奖励模型利用强化学习算法如PPO算法来优化策略 参考内容 RLHF训练的三个…

今年一定要做的副业兼职,1篇文章收入600,批量操作收入翻倍

随着公众号开放公域流量&#xff0c;流量主收入迅速攀升&#xff0c;吸引了众多投资者纷纷涌入这一领域&#xff0c;通过流量主赚取了丰厚的利润。上周&#xff0c;我曾向大家介绍了一些借助公众号流量主实现盈利的策略。 然而&#xff0c;公众号的盈利途径远不止流量主一种。…

数据库(14)——DQL排序查询

DQL排序查询语法 SELECT 字段列表 FROM 表名 ORDER BY 字段1 排序方式1,字段2 排序方式2; 排序方式 ASC&#xff1a;升序 DESC&#xff1a;降序 注&#xff1a;如果是多字段排序&#xff0c;当第一个字段值相同时&#xff0c;才会根据第二个字段进行排序。如果不写排序方式默…

图像处理ASIC设计方法 笔记27 红外非均匀校正的两点定标校正算法

非均匀性校正(Non-Uniformity Correction, NUC)是一种在图像处理和传感器校准中常用的技术,用于改善图像传感器(如CCD或CMOS相机)的输出质量。这种校正主要针对传感器在不同像素之间可能存在的响应差异,这些差异可能是由于制造过程中的微小不完美导致的。 基本原理: 响应…

MAB规范(2):Introduction 介绍

Chapter1 Introduction 1.1 指南目的 MathWorks咨询委员会&#xff08;MAB&#xff09;指南规定了Simulink和Stateflow建模的重要基本规则。这些建模指南的总体目的是让建模者和控制系统模型的使用者能够简单、共同地理解。 指南的主要目标是&#xff1a; • 可读性  提高…

CentOS8安装opensips 3.5

环境&#xff1a;阿里云 操作系统CentOS8.5 依赖包安装&#xff1a; libmicrohttpd cd /usr/local/src wget https://ftp.gnu.org/gnu/libmicrohttpd/libmicrohttpd-latest.tar.gz tar vzxf libmicrohttpd-latest.tar.gz cd libmicrohttpd-1.0.1/./configure make make …

联芸科技偏高的关联交易:业绩波动性明显,海康威视曾拥有一票否决

《港湾商业观察》施子夫 5月31日&#xff0c;上交所上市审核委员会将召开2024年第14次审议会议&#xff0c;届时将审议联芸科技&#xff08;杭州&#xff09;股份有限公司招股书&#xff08;以下简称&#xff0c;联芸科技&#xff09;的首发上会事项。 据悉&#xff0c;此次系…

Github 2024-05-31 Java开源项目日报 Top10

根据Github Trendings的统计,今日(2024-05-31统计)共有10个项目上榜。根据开发语言中项目的数量,汇总情况如下: 开发语言项目数量Java项目10TypeScript项目1JavaGuide - Java 程序员学习和面试指南 创建周期:2118 天开发语言:Java协议类型:Apache License 2.0Star数量:1…

Rust 第三方库创建和导入(cargo --lib)

前言 日常开发过程中&#xff0c;难免会有一些工具方法&#xff0c;多个项目之间可能会重复使用。 所以将这些方法集成到一个第三方包中方便后期维护和管理&#xff0c; 比如工具函数如果需要修改&#xff0c;多个项目可能每个都需要改代码&#xff0c; 抽离到单独的包中只需要…

SG7050EEN差分晶体振荡器:为5G路由器提供卓越的时钟源

随着5G技术的快速发展&#xff0c;5G路由器作为连接高速网络的重要设备&#xff0c;正迅速普及。为了确保5G路由器在高宽带和低延迟的网络环境中表现出色&#xff0c;选择一款高性能的晶体振荡器至关重要。爱普生推出的SG7050EEN差分晶体振荡器&#xff0c;以其高精度、低相位噪…

【linux软件基础知识】链表数据结构

双向循环链表 新链表是用LIST_HEAD(list_name)宏创建的。如上图中的(b)空链表所示,它申明类型为 list head的变量name,该变量作为新链表头的占位符。LIST_HEAD(list_name)宏还初始化 list head数据结构的 prev和next 字段,让它们指向list_name 变量本身。代码如下 #define…

0基础学习Elasticsearch-Quick start

文章目录 1 背景2 前言3 快速部署ES4 快速部署Kibana5 发送请求给ES5.1 打开Kibana控制台5.2 通过REST API发送请求5.3 通过curl发送请求5.4 添加数据5.4.1 添加单个document5.4.2 添加多个document 5.5 搜索数据5.5.1 搜索所有documents5.5.2 match查询 6 总结 1 背景 因电商项…

【算法】模拟算法——外观数组(medium)

题解&#xff1a;模拟算法——外观数组(medium) 目录 1.题目2.题解3.参考代码4.总结 1.题目 题目链接&#xff1a;LINK 2.题解 首先应该理解题意&#xff1a; 就是开始给你一个字符串&#xff0c;然后你对其进行描述。 描述规则是&#xff1a;连续的数字为一组&#xff0c;…

一、大模型推理

https://github.com/hiyouga/LLaMA-Factory/blob/main/README_zh.md https://github.com/hiyouga/LLaMA-Factory/blob/main/examples/README_zh.md 安装 v7.1 https://github.com/hiyouga/LLaMA-Factory/releases/tag/v0.7.1 git clone --depth 1 https://github.com/hiyoug…

docker 快速搭建django项目环境(DockerFile)文件基础搭建

首先需要搭建好docker环境&#xff0c;docker环境就不在这里叙述&#xff0c;如果想学在评论区留言小编后期更新由linux系统到docker的安装做一个详细的教程。 下面我们开始今天的重点&#xff1a; 1、第一步&#xff1a;我们在任意&#xff08;linux&#xff09;路径下创建Do…