【C】字符串函数和内存函数的介绍

news2024/11/23 23:30:38

库函数(这些函数都在头文件string.h中)

  • 字符串函数
    • 求字符串长度
      • strlen
    • 长度不受限的字符串函数
      • strcpy
      • strcmp
      • strcat
    • 长度受限的字符串函数
      • strncpy
      • strncmp
      • strncat
    • 字符串查找
      • strstr
      • strtok
    • 错误信息报告
      • strerror
    • 字符操作
      • 字符分类函数
      • 字符转换函数
  • 内存函数
    • memcpy
    • memmove
    • memset
    • memcmp

字符串函数

求字符串长度

strlen

size_t strlen ( const char * str );

字符串已经 ‘\0’ 作为结束标志,strlen函数返回的是在字符串中 ‘\0’ 前面出现的字符个数(不包含 ‘\0’ )。
参数指向的字符串必须要以 ‘\0’ 结束。
注意函数的返回值为size_t,是无符号的( 易错 )

代码演示:

#include <stdio.h>
#include <string.h>

int main()
{
	char arr[] = "abcdef";
	printf("%d", strlen(arr));
	return 0;
}

运行结果:

在这里插入图片描述

长度不受限的字符串函数

strcpy

char* strcpy(char * destination, const char * source );

源字符串必须以 ‘\0’ 结束。
会将源字符串中的 ‘\0’ 拷贝到目标空间。
目标空间必须足够大,以确保能存放源字符串。
目标空间必须可变。

代码演示:

#include <stdio.h>
#include <string.h>

int main()
{
	char arr[] = "xxxxxxxxxxxxxx";
	char str[] = "123456";
	strcpy(arr, str);
	printf("%s", arr);
	return 0;
}

运行结果:
在这里插入图片描述

strcmp

int strcmp ( const char * str1, const char * str2 );

第一个字符串大于第二个字符串,则返回大于0的数字
第一个字符串等于第二个字符串,则返回0
第一个字符串小于第二个字符串,则返回小于0的数字

这里的比较是一个字符一个字符比较的。
代码演示:

#include <stdio.h>
#include <string.h>

int main()
{
	printf("%d\n", strcmp("abcc", "abcd"));
	printf("%d\n", strcmp("abcd", "abcd"));
	printf("%d\n", strcmp("abce", "abcd"));

	return 0;
}

运行结果:
在这里插入图片描述

strcat

char * strcat ( char * destination, const char * source );

源字符串必须以 ‘\0’ 结束。
目标空间必须有足够的大,能容纳下源字符串的内容。
目标空间必须可修改。

这个函数是在字符串后面追加一个字符串。
代码演示:

#include <stdio.h>
#include <string.h>

int main()
{
	char arr[20] = "hello ";
	char str[] = "world";
	printf("%s\n", strcat(arr,str));
	return 0;
}

运行结果:
在这里插入图片描述

长度受限的字符串函数

这里的受限制是我我们自己可以指定拷贝的字节数,或追加的字节数,或比较的字节数。

strncpy

char * strncpy ( char * destination, const char * source, size_t num );

这里比strcpy多了一个参数,来指定拷贝的大小

拷贝num个字符从源字符串到目标空间。
如果源字符串的长度小于num,则拷贝完源字符串之后,在目标的后边追加0,直到num个。

代码演示:

#include <stdio.h>
#include <string.h>

int main()
{
	char arr[] = "xxxxxxxxxxxxxxxx";
	char str[] = "123456";
	printf("%s\n", strncpy(arr, str, 3));
	return 0;
}

运行结果:
在这里插入图片描述

strncmp

int strncmp ( const char * str1, const char * str2, size_t num );

比较到出现另个字符不一样或者一个字符串结束或者num个字符全部比较完。
第一个字符串大于第二个字符串,则返回大于0的数字
第一个字符串等于第二个字符串,则返回0
第一个字符串小于第二个字符串,则返回小于0的数字

代码演示:

#include <stdio.h>
#include <string.h>

int main()
{
	printf("%d\n", strncmp("abcc", "abcd",3));
	printf("%d\n", strncmp("accd", "abcd",2));
	printf("%d\n", strncmp("bbce", "cbcd",1));
	return 0;
}

运行结果:
在这里插入图片描述

strncat

char * strncat ( char * destination, const char * source, size_t num );

代码演示:

#include <stdio.h>
#include <string.h>

int main()
{
	char arr[20] = "hello ";
	char str[] = "worldssss";
	puts(strncat(arr, str, 5));
	return 0;
}

运行结果:
在这里插入图片描述

字符串查找

strstr

char * strstr ( const char *, const char * );

这个是查找子字符串,如果查找到了,就返回被查找字符串中子字符串的地址。
如果没有找到就返回NULL。

代码演示:

#include <stdio.h>
#include <string.h>

int main()
{
	char str[] = "abcdef";
	char arr[] = "bcd";
	printf("%s", strstr(str, arr));
	return 0;
}

运行结果:
在这里插入图片描述

strtok

char * strtok ( char * str, const char * sep );

sep参数是个字符串,定义了用作分隔符的字符集合
第一个参数指定一个字符串,它包含了0个或者多个由sep字符串中一个或者多个分隔符分割的标记。
strtok函数找到str中的下一个标记,并将其用 \0 结尾,返回一个指向这个标记的指针。(注:strtok函数会改变被操作的字符串,所以在使用strtok函数切分的字符串一般都是临时拷贝的内容并且可修改。)
strtok函数的第一个参数不为 NULL ,函数将找到str中第一个标记,strtok函数将保存它在字符串中的位置。
strtok函数的第一个参数为 NULL ,函数将在同一个字符串中被保存的位置开始,查找下一个标记。
如果字符串中不存在更多的标记,则返回 NULL 指针。

代码演示:

#include <stdio.h>
#include <string.h>

int main()
{
	char str[] = "123.456.789@qq.com";
	char arr[] = ".@";
	char copy[20] = { 0 };
	strcpy(copy, str);
	char* ret = NULL;
	for (ret = strtok(copy, arr); ret != NULL; ret = strtok(NULL, arr))
	{
		printf("%s\n", ret);
	}

	return 0;
}

运行结果:
在这里插入图片描述

错误信息报告

strerror

char * strerror ( int errnum );

这个函数主要提示库函数的错误信息,每个数字都对应一种错误信息,当发生错误是,程序会将错误放在errno中。使用errno是必须包含errno.h头文件

字符操作

字符分类函数

在这里插入图片描述

字符转换函数

int tolower ( int c ); 大写字母转换小写
int toupper ( int c ); 小写字母转换大写

内存函数

内存函数是什么类型都可以用的

memcpy

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

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

代码演示:

#include <stdio.h>
#include <string.h>

int main()
{
	int arr[] = { 1,2,3,4,5,6,4,8,9 ,10};
	int arr1[10] = {0};
	int sz = sizeof(arr) / sizeof(arr[0]);
	for (int i = 0; i < 10; i++)
	{
		printf("%d ", arr1[i]);
	}
	printf("\n");
	memcpy(arr1, arr, sz * sizeof(int));
	for (int i = 0; i < 10; i++)
	{
		printf("%d ", arr1[i]);
	}
	printf("\n");
	return 0;
}

运行结果:
在这里插入图片描述
但是memcpy不能处理重叠的内容,重叠的内容要交给memmove来处理。

memmove

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

和memcpy的差别就是memmove函数处理的源内存块和目标内存块是可以重叠的。
如果源空间和目标空间出现重叠,就得使用memmove函数处理。

代码演示:

#include <stdio.h>
#include <string.h>

int main()
{
	char str[] = "12345678";
	memmove(str, str + 2, 3);
	puts(str);
	return 0;
}

运行结果:
在这里插入图片描述

memset

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

这个函数是将num个字节的内容设置为value。

代码演示:

#include <stdio.h>
#include <string.h>

int main()
{
	int arr[] = { 1,2,3,4,5,6,7,8,9,10 };
	int sz = sizeof(arr) / sizeof(arr[0]);
	memset(arr, 0, sz * sizeof(arr[0]));
	for (int i = 0; i < 10; i++)
	{
		printf("%d ", arr[i]);
	}
	return 0;
}

运行结果:
在这里插入图片描述
这个函数要注意设置的内容是以字节为单位的。

memcmp

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

比较从ptr1和ptr2指针开始的num个字节

返回值如下:
在这里插入图片描述
从第一个字节开始比较,如果不相同,*ptr1大于 *ptr2时返回大于0的数字,小于时返回小于0的数字,num个字节都相同返回0.
代码演示:

#include <stdio.h>
#include <string.h>

int main()
{
	int arr1[] = { 1,2,3,4,5,6 };
	int arr2[] = { 1,2,3,4,5,6 };
	printf("%d", memcmp(arr1, arr2, 6 * 4));
	return 0;
}

运行结果:
在这里插入图片描述

今天的分享就到这里吧,感谢大家的关注和支持。

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

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

相关文章

测试必备的15个docker命令,你都掌握了吗

1、Docker容器信息 ##查看docker容器版本docker version##查看docker容器信息docker info##查看docker容器帮助docker --help 2、镜像操作 提示&#xff1a;对于镜像的操作可使用镜像名、镜像长ID和短ID。 2.1、镜像查看 ##列出本地imagesdocker images##含中间映像层docke…

iview-admin使用小结

首先在使用一个框架之前一定要完整的看一下相关文档&#xff0c;因为框架中会封装常用的功能&#xff0c;也会更加符合大众要求。在ui设计图上&#xff0c;可能实现某个功能设计图中给出的交互并不是很好&#xff0c;而在框架中有更好的组件可以实现&#xff0c;但因为没有看文…

物联网技术、测试要点和测试标准

目录 物联网定义 物联网中最常用的技术 物联网测试概述 测试人员在物联网中面临的挑战 测试物联网系统时使用了各种工具 &#x1f381;更多干货 完整版文档下载方式&#xff1a; 物联网定义 物联网&#xff1a;利用嵌入式电子设备、微芯片等连接车辆、家电、医疗设备&am…

广州华锐互动 | 鸡养殖VR教育实训系统

鸡养殖VR教育实训系统由广州华锐互动开发&#xff0c;是一种基于虚拟现实技术的培训工具&#xff0c;旨在为鸡养殖行业的从业人员提供更加直观、生动的学习体验。该系统通过虚拟现实技术&#xff0c;将鸡养殖过程中的各种场景、操作和技能呈现在学员面前&#xff0c;让学员可以…

关于 Linux 的常用命令

目录 前言什么是 Linux获得 Linux 环境为什么使用命令控制关于 XShell 下的复制粘贴 Linux 常用命令ls (罗列文件)cd (切换目录)pwd (显示当前路径)touch (创建一个空文件)cat (读取文件内容)man (查看用户手册)echo (回显)vim (文件编辑器)mkdir (创建目录)rm (删除目录/文件)…

数仓常见问题以及解决方案yyds

文章目录 01 数据仓库现状业务系统侧【上游】数仓内部数据应用测【下游】 02 如何解决问题业务系统侧【上游】数仓内部 03 体系化架构设计一致性维度一致性事实数据应用侧【下游】 建设可视化的取数平台 大家好&#xff0c;我是脚丫先生 (o^^o) 看到几篇不错的文章&#xff0c…

App Inventor 2 从.aia项目文件中提取.aix拓展包

从.aia项目文件中提取.aix拓展包的步骤 如果看到一个项目中&#xff0c;用到了拓展&#xff0c;但拓展的帮助中没有原链接&#xff0c;这时就可以考虑从项目文件中进行提取&#xff1a; 导出项目.aia文件&#xff1a; 在电脑的“下载”目录查看.aia项目文件&#xff1a; 将.a…

写在2023年年中

写在2023年年中 收拾旧山河再出发 很久没有写规划了&#xff0c;博客也很少写&#xff0c;着实是太懒了。想想自己年纪也不小了&#xff0c;加上程序员的环境越来越不好&#xff0c;总得想想自己的出路不是。 目标 提升系统设计能力保持算法刷题能力(一般面试需要)知识输出能…

RabbitMQ工作模式代码示例及用SpringBoot整合RabbitMQ

一&#xff0c;RabbitMQ的工作模式 RabbitMQ 的工作模式是指 RabbitMQ 中不同的消息传递方式&#xff0c;包括简单模式、工作队列模式、发布订阅模式、路由模式和主题模式 。这些工作模式适用于不同的应用场景。详细的文档可参照RabbitMQ的官网&#xff1a;RabbitMQ: easy to u…

基于JavaSwing+MySQL的员工工资管理系统

点击以下链接获取源码&#xff1a; https://download.csdn.net/download/qq_64505944/88042468?spm1001.2014.3001.5503 JDK1.8 MySQL5.7

虚拟与现实的交融:VR与数字孪生的融合之道

VR即虚拟现实&#xff08;Virtual Reality&#xff09;和数字孪生&#xff08;Digital Twin&#xff09;是当今科技领域的两大热门概念&#xff0c;VR以其沉浸式的体验和逼真的虚拟环境&#xff0c;让用户身临其境&#xff0c;开启了全新的交互方式和感官体验&#xff1b;而数字…

副业做什么比较靠谱,不想只靠一个收入

科思创业汇 大家好&#xff0c;这里是科思创业汇&#xff0c;一个轻资产创业孵化平台。赚钱的方式有很多种&#xff0c;我希望在科思创业汇能够给你带来最快乐的那一种&#xff01; 如今做一些副业能不能有一点安全感&#xff0c;分享一些可靠的副业&#xff0c;坚持下去&…

Abandoning the Bayer-Filter to See in the Dark 论文阅读笔记

这是CVPR2022的一篇暗图增强的文章&#xff0c;TCL AI Lab与福州大学&#xff0c;韩国延世大学&#xff0c;安徽大学的合作论文网络以黑暗环境下拍摄的color raw为输入&#xff0c;用一个de-bayer-filter module恢复无拜尔滤波器的raw data&#xff08;文章认为拜尔滤波器使得光…

leetcode 987. 二叉树的垂序遍历(java)

二叉树的垂序遍历 leetcode 987. 二叉树的垂序遍历题目描述DFS 优先队列&#xff08;堆&#xff09;代码演示 二叉树专题 leetcode 987. 二叉树的垂序遍历 来源&#xff1a;力扣&#xff08;LeetCode&#xff09; 链接&#xff1a;https://leetcode.cn/problems/vertical-orde…

AI文本标注的概念,类型和方法

我们每天都在与不同的媒介&#xff08;例如文本、音频、图像和视频&#xff09;交互&#xff0c;我们的大脑对收集到的信息进行处理和加工&#xff0c;从而指导我们的行为。在我们日常接触到的信息中&#xff0c;文本是最常见的媒体类型之一&#xff0c;由我们交流使用的语言构…

优化SQL查询实现高效数据检索(一)

大家好&#xff0c;SQL&#xff08;结构化查询语言&#xff09;可以帮助大家从数据库中收集数据&#xff0c;它是专为此而设计的&#xff0c;换句话说&#xff0c;它使用行和列来处理数据&#xff0c;让使用者能够使用SQL查询来操作数据库中的数据。 SQL查询 SQL查询是一系列…

11-2.箭头函数与函数的this问题

目录 1 箭头函数 1.1 基本使用 1.2 在只有一个参数的时候&#xff0c;小括号可以省略 1.3 只有一行时&#xff0c;可以省略大括号 1.4 只有一行时的return问题 1.5 直接返回一个对象 1.6 箭头函数使用剩余参数 2 this问题 2.1 直接打印this 2.2 fucntion定…

接口工具Postman知多少

目录 前言&#xff1a; Postman简介 如何使用Postman 1&#xff09;主界面 2&#xff09;测试用例的创建 3&#xff09;请求结果 4&#xff09;测试集的创建 使用方法&#xff1a; 前言&#xff1a; Postman是一个流行的API开发和测试工具&#xff0c;它提供了丰富的功…

38. QT在工控机Linux系统上调试机器人注意事项

1. QtCreator项目编译目录问题 当使用QtCreator创建一个新项目之后,对于代码编译产生的最终文件保存路径一般也会确定下来,QtCreator会帮助我们在同级目录下创建保存路径。例如下图:带有蓝色框的文件夹为项目源码,左侧的文件夹即为项目编译后产生的文件夹 如果在某种情况…

Unity | 向量、矩阵、齐次坐标

目录 一、向量点乘&叉乘 1.点乘 1.1 公式 1.2 几何意义 2.叉乘 2.1 公式 2.2 几何意义 二、矩阵点乘&叉乘 1.矩阵 2.矩阵的点乘 3.矩阵的叉乘 三、矩阵旋转 四、齐次坐标 一、向量点乘&叉乘 1.点乘 又称内积&#xff0c;结果是个标量&#xff0c; 1…