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

C语言_内存函数

内存函数是 C 标准库中的一组函数,用于管理和操作内存。使用时需要包含头文件<string.h>

1. memcpy的使用和模拟实现

函数形式如下:

void* memcpy(void* destination, const void* source, size_tnum);

函数解析和注意事项:

  • memcpy函数从source的位置开始向后复制num个字节的数据到destination指向的内存位置
  • 函数遇到'\0'的时候不会停下来
  • sourcedestination对应的字节上有任何的重叠,复制的结果都是未定义的

函数的使用:

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

函数的模拟实现:

void* my_memcpy(void* dest, const void* src, size_t num){void* ret = dest;assert(dest);assert(src);while(num--){*(char*)dest = *(char*)src;dest = (char*)dest + 1;src = (char*)src + 1;}return ret;
}

2. memmove的使用和模拟实现

函数形式如下:

void* memmove(void* destination, const void* source, size_t num);

函数的解析和注意事项:

  • memmovememcpy的区别就是memmove函数处理的源内存块和目标内存块是可以重叠的
  • 源空间和目标空间出现重叠,就得使用memmove函数处理

函数的使用:

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

函数的模拟实现:

void* my_memmove(void* dest, const void* src, size_t num){if(dest < src){while(num--){ // 前 -> 后*(char*)dest = *(char*)src;dest = (char*)dest + 1;src = *(char)src + 1;}}else{ // 后 -> 前while(num--){*((char*)dest + num) = *((char*)src + num);}}
}

memcpy函数只能处理不重叠的内存块,而memmove既能处理重叠的内存块,又能处理不重叠的内存块,所以我们在写代码的时候,尽量使用memmove函数。

3. memset的使用

函数形式如下:

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

函数作用:

memset函数用来设置内存,将内存中的值以字节为单位设置为想要的内容

函数的使用:

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

4. memcmp的使用

函数的形式如下:

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

函数的作用:

  • 比较从ptr1ptr2指针指向的位置开始,向后的num个字节
  • 返回值如下:
    在这里插入图片描述

函数的使用:

#include<stdio.h>
#include<string.h>int main(){char buffer1[]="hello world!!";char buffer2[]="hello brother!!";if(memcmp(buffer1, buffer2, sizeof(str1)) > 0)printf("'%s' is greater than '%s'.\n", buffer1, buffer2);else if (memcmp(buffer1, buffer2, sizeof(str1)) < 0) printf("'%s' is less than '%s'.\n", buffer1, buffer2);elseprintf("'%s' is the same as '%s'.\n", buffer1, buffer2);return 0;
}
http://www.lryc.cn/news/457811.html

相关文章:

  • 基于s32ds平台指定变量储存位置
  • 什么是快充协议、支持多协议的USB Type-C受电端取电芯片
  • 在Vue CLI项目中使用ECharts:详细指南
  • 第二阶段:mysql(学完就隐藏版)
  • Spring Cloud微服务
  • 后端复习资料
  • C++和OpenGL实现3D游戏编程【连载14】——VBO、VAO和EBO应用
  • AI + 智能互助平台(一点杂想)
  • 其他浏览器可以联网,但edge不能联网
  • Redis 缓存淘汰策略:LRU 和 LFU 的缺点及解决方案详解
  • 软件工程pipeline梳理
  • npm运行时出现npm ERR! builtins is not a function报错!
  • 2024年软件设计师中级(软考中级)详细笔记【5】软件工程基础知识上(分值10+)
  • C++:vector(题目篇)
  • JS 怎么监听复制事件 并获取复制内容 并修改复制文本内容
  • 安卓使用.9图实现阴影效果box-shadow: 0 2px 6px 1px rgba(0,0,0,0.08);
  • CSS3-Day1
  • 网站集群批量管理-Ansible(ad-hoc)
  • github学生认证(Github Copilot)
  • 【SQL调优指南--附带实例】
  • Java基础(下)
  • 【python】极简教程1-何为程序
  • 【Transformer】Selective Attention Improves Transformer
  • 博客项目自动化测试(一)
  • 电商商品API接口系列(商品详情数据)商品比价、数据分析、自营商城上货
  • 排序算法总结(一)冒泡排序和选择排序
  • 伺服电动缸
  • 深度学习中的logit到底是什么?
  • idea使用记录
  • Python - HTTP servers