【C语言】内存函数详细讲解

news2024/11/13 11:08:03

文章目录

  • 前言
  • strerror的声明和使用
  • 字符串分类函数
  • 字符转换函数
  • 内存拷贝函数(memcpy)
    • memcpy的声明和使用
    • memcpy函数的模拟实现
  • 内存拷贝函数(memmove)
    • memmove的声明和使用
    • memmove模拟实现
  • 内存比较函数(memcmp)
    • memcmp的声明和使用
  • 内存设置函数(memset)
    • memset的使用
  • 最后

前言

前面我们学习了字符串函数,但字符串函数只能对字符串进行操作,但在C语言中有很多的数据类型,所以本章讲解一些内存函数,这些函数可以对任何数据类型进行拷贝、追加、比较。


strerror的声明和使用

char * strerror ( int errnum );

在这里插入图片描述

  • 获取指向错误消息字符串的指针。
  • 解释错误码(errnum)所对应的错误信息。
  • 必须包含头文件errno.h
  • strerror 生成的错误字符串可能特定于每个系统和库实现。

在vs2022编译编译器下的运行结果
在这里插入图片描述

字符串分类函数

函数如果他的参数符合下列条件就返回真
iscntrl任何控制字符
isspace空白字符:空格‘ ’,换页‘\f’,换行’\n’,回车‘\r’,制表符’\t’或者垂直制表符’\v’
isdigit十进制数字 0~9
isxdigit十六进制数字,包括所有十进制数字,小写字母a-f,大写字母A-F
islower小写字母a~z
isupper大写字母A~Z
isalpha字母a-z或A-Z
isalnum字母或者数字,a-z,A-Z,0-9
ispunct标点符号,任何不属于数字或者字母的图形字符(可打印)
isgraph任何图形字符
isprint任何可打印字符,包括图形字符和空白字符

这些函数都很简单根据意思使用就行,下面简单用几个。

// 字符串分类函数使用
int main()
{
	//检查是否为小写字符
	if (islower('c'))
	{
		printf("是小写字符");
	}
	return 0;
}

在这里插入图片描述

字符转换函数

int tolower ( int c ); // 将大写转化小写
int toupper ( int c );//将小写转化为大写

//tolower的使用
int main()
{
	char arr[] = { "Hello WoRD" };
	for (int i = 0; i < sizeof(arr); i++)
	{
		//大写转化为小写
		arr[i]=tolower(arr[i]);
	}
	printf("%s", arr);
	return 0;
}

在这里插入图片描述

toupper的使用,是一样的,这里就不展示了,读者可以自己尝试一下。

内存拷贝函数(memcpy)

memcpy的声明和使用

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

在这里插入图片描述

  • 函数memcpy从source的位置开始向后复制num个字节的数据到destination的内存位置。
  • 这个函数在遇到 ‘\0’ 的时候并不会停下来。
  • 如果source和destination有任何的重叠,复制的结果都是未定义的。

使用

//memcpy的拷贝整形使用
int main()
{
	int arr[] = { 1,2,3,4,5,6,7,8 };
	int arr1[15];
	memcpy(arr1, arr, sizeof(arr));
	for (int i = 0; i < sizeof(arr) / sizeof(arr[0]); i++)
	{
		printf("%d ", arr1[i]);
	}
	return 0;
 }

在这里插入图片描述

memcpy函数的模拟实现

//memcpy模拟实现
void* my_memcpy(void* des, const void* sour, size_t num)
{
	//
	assert(des && sour);
	while (num)
	{
		*(char*)des = *(char*)sour;
		++(char*)des;
		++(char*)sour;
		num--;
	}
}

内存拷贝函数(memmove)

memmove的声明和使用

void * memmove ( void * destination, const void * source, size_t num );
  • 和memcpy的差别就是memmove函数处理的源内存块和目标内存块是可以重叠的。
  • 如果源空间和目标空间出现重叠,就得使用memmove函数处理。
    使用
int main()
{
	int arr[] = { 1,2,3,4,5,6,7,8 };
	memmove(arr, arr + 2, 16);
	for (int i = 0; i < sizeof(arr) / sizeof(arr[0]); i++)
	{
		printf("%d ", arr[i]);
	}
	return 0;
}

在这里插入图片描述

memmove模拟实现

在这里插入图片描述

有重叠部分时

  • 当des小于sour的地址时从前向后拷贝。
  • 当des大于sour的地址时从后向前拷贝

没重叠部分时

  • 从前向后拷贝、从后向前拷贝都可以。
void* my_memmove(void* des, const void* sour, size_t num)
{
	assert(des&& sour);
	void* ret = des;
	//从前向后拷贝
	if (des < sour)
	{
		while (num)
		{
			*(char*)des = *(char*)sour;
			++(char*)des;
			++(char*)sour;
			num--;
		}
		return ret;
	}
	//从后向前拷贝
	while (num--)
	{
		*((char*)des + num) = *((char*)sour + num);
	}
	return ret;
}

内存比较函数(memcmp)

memcmp的声明和使用

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

在这里插入图片描述

  • 比较从ptr1和ptr2指针开始的num个字节
  • 请注意,与 strcmp 不同,该函数在找到 null 字符后不会停止比较。
  • 返回值如下:
    在这里插入图片描述
    使用
int main () 
{ 
 	char buffer1[] = "DWgaOtP12df0"; 
	 char buffer2[] = "DWGAOTP12DF0"; 
 	int n; 
 	n=memcmp ( buffer1, buffer2, sizeof(buffer1) ); 
 	if (n>0) 
	 printf ("'%s' is greater than '%s'.\n",buffer1,buffer2); 
 	else if (n<0)
 	 printf ("'%s' is less than '%s'.\n",buffer1,buffer2); 
 	else 
 	printf ("'%s' is the same as '%s'.\n",buffer1,buffer2); 
	 return 0; 
} 

在这里插入图片描述

内存设置函数(memset)

memset的使用

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

在这里插入图片描述

  • 把ptr指向的前num个字节的空间设置成value的值。
int main()
{
	char arr[] = { "hello word" };
	memset(arr, 'x', 5);
	printf("%s", arr);
}

在这里插入图片描述


最后

感谢大家的观看, 大家可以在评论区留言,你们的支持就是我最大的动力。

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

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

相关文章

【数字ic自整资料】常见串行总线协议

参考链接 IIC总线的原理与Verilog实现_iic verilog-CSDN博客 I2C&#xff08;IIC&#xff09;的仲裁、时钟同步和时钟扩展_i2c,clock stretch波形-CSDN博客 精解IIC协议_iic写数据-CSDN博客 串行通信——UART总结-CSDN博客 SPI协议详解&#xff08;图文并茂超详细&#xf…

java.lang.IllegalAccessError: class lombok.javac.apt.LombokProcessor

更换JDK java.lang.IllegalAccessError: class lombok.javac.apt.LombokProcessor (in unnamed module 0x3302035b) cannot access class com.sun.tools.javac.processing.JavacProcessingEnvironment (in module jdk.compiler) because module jdk.compiler does not export …

【大模型推理】大模型前向推理过程详解

文章目录 前期准备环境安装下载模型Qwen2-7b模型架构vscode配置launch.json文件 前向推理debug深入分析预测第一个next_token预测第二个next_token 为了搞清楚&#xff0c;大模型前向推理的具体流程&#xff0c;本文以Qwen2-7B-Instruct为例&#xff0c;通过直接debug官方推理示…

战外网配置——光猫桥接+路由器PPPoE拨号+防火墙外网链路健康检查+外网流量负载均衡

一、适用场景&#xff1a; 1、企业规模较大时&#xff0c;1条公网带宽流量可能不足&#xff0c;需要用到多条公网出口时。 2、企业有业务需要静态ip映射&#xff0c;但是因静态ip专线价格较高&#xff0c;所以需要拨号光纤承载较多的下行流量。 3、当公网出口有多条链路&#…

最大矩阵和

题目描述 给定一个二维整数矩阵&#xff0c;要在这个矩阵中选出一个子矩阵. 使得这个子矩阵内所有的数字和尽量大&#xff0c;我们把这个子矩阵称为和最大子矩阵 子矩阵的选取原则是原矩阵中一块相互连续的矩形区域。 输入描述 输入的第一行包含2个整数n,m(1< n,m< 10…

C++设计模式——Interpreter解释器模式

一&#xff0c;解释器模式的定义 解释器模式是一种行为型设计模式&#xff0c;它用于定义一个语言的文法并解析语言中的表达式&#xff0c;使开发者可以实现自定义语言&#xff0c;并通过解释器对语言中的表达式进行解析和执行。 解释器模式主要用于解决对特定表达式的解析与…

python-游戏自动化(三)(实战-豆腐女孩)

前提准备 特别注意&#xff1a; 本节教程所演示的模拟器分辨率设置为 720x1080&#xff08;手机版&#xff09;&#xff0c;电脑分辨率设置大720x1080并且没有设置放大。 今天的课程开始之前我们来回顾一下昨天所学的知识内容&#xff0c;因为今天要学的内容和昨天内容…

CogView-3-Plus:深度解锁智谱AI的图像生成新力量

一、引言&#xff1a;AI助力创意与效率的全面提升 在如今这个瞬息万变的科技时代&#xff0c;AI大模型早就不是实验室里的“神秘武器”&#xff0c;它们已经实实在在地融入到我们的日常工作中了&#xff0c;尤其是在图像生成和内容创作这块儿&#xff0c;简直是效率神器。只要几…

Leetcode3270. 求出数字答案

Every day a Leetcode 题目来源&#xff1a;3270. 求出数字答案 解法1&#xff1a;模拟 按题意模拟。 代码&#xff1a; /** lc appleetcode.cn id3270 langcpp** [3270] 求出数字答案*/// lc codestart class Solution { public:int generateKey(int num1, int num2, int…

基于python+django+vue鲜花商城系统

作者&#xff1a;计算机学姐 开发技术&#xff1a;SpringBoot、SSM、Vue、MySQL、JSP、ElementUI、Python、小程序等&#xff0c;“文末源码”。 专栏推荐&#xff1a;前后端分离项目源码、SpringBoot项目源码、SSM项目源码 系统展示 【2025最新】基于pythondjangovueMySQL的线…

反射(java)

一、junit单元测试框架 1、单元测试 就是针对最小的功能单元&#xff08;方法&#xff09;&#xff0c;编写测试代码对其进行正确性测试。 之前的是如何进行单元测试的&#xff1f; 有啥问题&#xff1f; 1、只能在ma方法编写测试代码&#xff0c;去调用其他方法进行测试。…

CCS811二氧化碳传感器详解(STM32)

目录 一、介绍 二、传感器原理 1.原理图 2.引脚描述 3.工作原理介绍 三、程序设计 main.c文件 ccs811.h文件 ccs811.c文件 四、实验效果 五、资料获取 项目分享 一、介绍 CCS811模块是一种气体传感器&#xff0c;可以测量环境中TVOC(总挥发性有机物质)浓度和eCO2…

OPPO 全家桶:Find X8/Pro、Pad3 Pro与Enco X3即将10月登场

随着科技的不断发展&#xff0c;智能手机、平板电脑和耳机等电子产品已经成为我们日常生活中不可或缺的一部分。 作为全球知名的科技企业&#xff0c;OPPO一直致力于为消费者提供优质的产品和服务。 近日&#xff0c;有关OPPO全家桶将在10月份“凑齐”的消息引起了广泛关注。…

Elemnt-UI + 递归组件实现后台管理系统左侧菜单

Elemnt-UI 递归组件实现后台管理系统左侧菜单 在 Vue.js 中&#xff0c;允许你编写一个组件来表示一个节点&#xff0c;而这个节点可以包含多个子节点&#xff0c;每个子节点又可以是同样的组件。这种方式使得组件能够处理无限层级的嵌套结构。 应用场景 递归组件非常适合处…

2013年

B D B C D 分支结点是非叶结点 B 47 C A C C D D C A C

2010-2022年各省乡村振兴新质生产力相关变量数据(40+指标)

2010-2022年各省乡村振兴新质生产力相关变量数据&#xff08;40指标&#xff09; 1、时间&#xff1a;2010-2022年 2、来源&#xff1a;统计年鉴、能源统计年鉴、农村统计年鉴、人口和就业统计年鉴、城乡建设统计年鉴以及各省份统计年鉴 3、指标&#xff1a;省份、年份、分地…

信号量(二值信号量和计数信号量)和互斥量

信号量 信号量&#xff08;Semaphore&#xff09; 是一种实现任务间通信的机制&#xff0c; 可以实现任务之间同步或临界资源的互斥访问&#xff0c; 常用于协助一组相互竞争的任务来访问临界资源。 在多任务系统中&#xff0c; 各任务之间需要同步或互斥实现临界资源的保护&a…

图神经网络介绍3

1. 图同构网络&#xff1a;Weisfeiler-Lehman 测试与图神经网络的表达力 本节介绍一个关于图神经网络表达力的经典工作&#xff0c;以及随之产生的另一个重要的模型——图同构网络。图同构问题指的是验证两个图在拓扑结构上是否相同。Weisfeiler-Lehman 测试是一种有效的检验两…

第二期: 第二节 , 逻辑编程 , gpio

1 首先就是 看原理图&#xff1a; 这里有两个 &#xff2c;&#xff25;&#xff24; 核心板的原理图。 可以看到 是这个脚。 &#xff12; 然后就是 查看数据手册。 从 数据手册可以看出 &#xff0c;一共有这么多的 gpio 组&#xff0c; 但是这些 组 是有复用的&#xf…

多文件编程实现链表创建,插入,输出(上)

linklist.c #include "linklist.h" //创建空的链表&#xff0c;为头结点在堆区分配空间 linklist_t *creat_empty_linklist() {linklist_t *head NULL;head (linklist_t *) malloc(sizeof(linknode_t));if(NULL head){printf("malloc is fail!\n");ret…