C语言——内存函数【memcpy,memmove,memset,memcmp】

2024-01-06 16:28

本文主要是介绍C语言——内存函数【memcpy,memmove,memset,memcmp】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

📝前言:
在之前的文章C语言——字符函数和字符串函数(一)中我们学习过strcpystrcat等用来实现字符串赋值和追加的函数,那么除了字符内容,其他的数据(例如整型)能否被复制或者移动呢
答案是:可以的!

这篇文章我们就来学习一下C语言内存函数
1,memcpy
2,memmove
3,memset
4,memcmp

🎬个人简介:努力学习ing
📋个人专栏:C语言入门基础
🎀CSDN主页 愚润求学
🌄每日鸡汤:慕强,所以要变得更强


文章目录

  • 一,memcpy
    • 1,基本介绍
    • 2,使用实例
  • 二,memmove
    • 1,基本介绍
    • 2,使用实例
  • 三,memset
    • 1,基本介绍
    • 2,使用实例
  • 四,memcmp
    • 1,基本介绍
    • 2,使用实例

一,memcpy

1,基本介绍

我们先看C library对它的介绍👇🏻
在这里插入图片描述
🔍重点提取:
①所在头文件:string.h
②函数原型:
void * memcpy ( void * destination, const void * source, size_t num );
destination(目标空间),source(源头),num(字节个数)
③函数功能:
●从source指向的位置开始向后复制num个字节的数据到destination指向的位置
④注意:
●函数在遇到\0的时候不会停止
●如果要复制num个字节,那么source和destination的数组大小至少为num字节
●如果source和destination的内存块有重叠,那复制的结果是未定义的(有重叠的时候,最好用memmove)

2,使用实例

假如我们要把整型数组arr1中的前五个数复制到arr2中:

#include<stdio.h>
#include<string.h>
int main()
{int arr1[] = { 0,1,2,3,4,5,6,7,8,9 };int arr2[10] = { 0 };memcpy(arr2, arr1,5*sizeof(int)); //复制5个整型(共20个字节)//打印arr2 观察结果for (int i = 0; i < 10; i++){printf("%d ", arr2[i]);}return 0;
}

输出结果👇🏻
在这里插入图片描述
可以发现:数组arr1的前五个数据,被复制到了arr2前五个数据的位置

二,memmove

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


🌈我的分享也就到此结束啦🌈
要是我的分享也能对你的学习起到帮助,那简直是太酷啦!
若有不足,还请大家多多指正,我们一起学习交流!
📢公主,王子:点赞👍→收藏⭐→关注🔍
感谢大家的观看和支持!祝大家都能得偿所愿,天天开心!!!

这篇关于C语言——内存函数【memcpy,memmove,memset,memcmp】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/576914

相关文章

NameNode内存生产配置

Hadoop2.x 系列,配置 NameNode 内存 NameNode 内存默认 2000m ,如果服务器内存 4G , NameNode 内存可以配置 3g 。在 hadoop-env.sh 文件中配置如下。 HADOOP_NAMENODE_OPTS=-Xmx3072m Hadoop3.x 系列,配置 Nam

hdu1171(母函数或多重背包)

题意:把物品分成两份,使得价值最接近 可以用背包,或者是母函数来解,母函数(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v) 其中指数为价值,每一项的数目为(该物品数+1)个 代码如下: #include<iostream>#include<algorithm>

科研绘图系列:R语言扩展物种堆积图(Extended Stacked Barplot)

介绍 R语言的扩展物种堆积图是一种数据可视化工具,它不仅展示了物种的堆积结果,还整合了不同样本分组之间的差异性分析结果。这种图形表示方法能够直观地比较不同物种在各个分组中的显著性差异,为研究者提供了一种有效的数据解读方式。 加载R包 knitr::opts_chunk$set(warning = F, message = F)library(tidyverse)library(phyl

透彻!驯服大型语言模型(LLMs)的五种方法,及具体方法选择思路

引言 随着时间的发展,大型语言模型不再停留在演示阶段而是逐步面向生产系统的应用,随着人们期望的不断增加,目标也发生了巨大的变化。在短短的几个月的时间里,人们对大模型的认识已经从对其zero-shot能力感到惊讶,转变为考虑改进模型质量、提高模型可用性。 「大语言模型(LLMs)其实就是利用高容量的模型架构(例如Transformer)对海量的、多种多样的数据分布进行建模得到,它包含了大量的先验

C++操作符重载实例(独立函数)

C++操作符重载实例,我们把坐标值CVector的加法进行重载,计算c3=c1+c2时,也就是计算x3=x1+x2,y3=y1+y2,今天我们以独立函数的方式重载操作符+(加号),以下是C++代码: c1802.cpp源代码: D:\YcjWork\CppTour>vim c1802.cpp #include <iostream>using namespace std;/*** 以独立函数

函数式编程思想

我们经常会用到各种各样的编程思想,例如面向过程、面向对象。不过笔者在该博客简单介绍一下函数式编程思想. 如果对函数式编程思想进行概括,就是f(x) = na(x) , y=uf(x)…至于其他的编程思想,可能是y=a(x)+b(x)+c(x)…,也有可能是y=f(x)=f(x)/a + f(x)/b+f(x)/c… 面向过程的指令式编程 面向过程,简单理解就是y=a(x)+b(x)+c(x)

C语言 | Leetcode C语言题解之第393题UTF-8编码验证

题目: 题解: static const int MASK1 = 1 << 7;static const int MASK2 = (1 << 7) + (1 << 6);bool isValid(int num) {return (num & MASK2) == MASK1;}int getBytes(int num) {if ((num & MASK1) == 0) {return

MiniGPT-3D, 首个高效的3D点云大语言模型,仅需一张RTX3090显卡,训练一天时间,已开源

项目主页:https://tangyuan96.github.io/minigpt_3d_project_page/ 代码:https://github.com/TangYuan96/MiniGPT-3D 论文:https://arxiv.org/pdf/2405.01413 MiniGPT-3D在多个任务上取得了SoTA,被ACM MM2024接收,只拥有47.8M的可训练参数,在一张RTX

如何确定 Go 语言中 HTTP 连接池的最佳参数?

确定 Go 语言中 HTTP 连接池的最佳参数可以通过以下几种方式: 一、分析应用场景和需求 并发请求量: 确定应用程序在特定时间段内可能同时发起的 HTTP 请求数量。如果并发请求量很高,需要设置较大的连接池参数以满足需求。例如,对于一个高并发的 Web 服务,可能同时有数百个请求在处理,此时需要较大的连接池大小。可以通过压力测试工具模拟高并发场景,观察系统在不同并发请求下的性能表现,从而

C语言:柔性数组

数组定义 柔性数组 err int arr[0] = {0}; // ERROR 柔性数组 // 常见struct Test{int len;char arr[1024];} // 柔性数组struct Test{int len;char arr[0];}struct Test *t;t = malloc(sizeof(Test) + 11);strcpy(t->arr,