字符串函数

目录

一、求字符串长度

strlen

用法:

注意:

用例:

二、长度不受限制的字符串函数

strcpy

用法:

注意:

用例:

strcat

用法:

注意:

用例:

strcmp

用法:

三、长度受限制的字符串函数介绍

strncpy

用法:

注意:

用例:

strnact

用法:

用例:

strncmp

用法:

字符串查找

strstr

用法:

用例:

strtok

用法:

注意:

用例:

​编辑

四、内存函数

memcpy

用法:​

注意: 

用例:

​memmove

用法:

注意:

用例:

memcmp

用法:

注意:

memset

用法:​

注意:



一、求字符串长度

strlen

用法:
 

strlen:返回 C 字符串 str 的长度。(与初始化的数组长度无关)

C字符串的长度由终止空字符确定:C 字符串的长度与字符串开头和终止空字符之间的字符数一样长(不包括终止空字符本身)。

注意:

1.字符串已经 '\0' 作为结束标志,strlen函数返回的是在字符串中 '\0' 前面出现的字符个数(不包含 '\0' )。

2. 参数指向的字符串必须要以 '\0' 结束。
char str[] = { 'a','b','c' };//以大括号加单引号组成的字符串需要自己加'\0'
strlen(str);//str末尾没有\0,故strlen使用非法

3.函数返回值为 size_t ,是无符号的。

用例:

/* strlen example */
#include <stdio.h>
#include <string.h>int main ()
{char szInput[256];printf ("Enter a sentence: ");gets (szInput);printf ("The sentence entered is %u characters long.\n",(unsigned)strlen(szInput));return 0;
}

样例输出: 

二、长度不受限制的字符串函数

strcpy

用法:

strcpy:复制字符串。

source 指向的 C 字符串复制到目标指向的数组中,包括终止的 '\0' 字符(并在该点停止)。

返回值:目标空间的起始地址。

注意:

1.源字符串必须以 '\0' 结束。
char arr1[5];
char arr2[] = { 'a','b','c' };strcpy(arr1, arr2);//arr2中不包含'\0',使用非法

2.会将源字符串中的 '\0' 拷贝到目标空间。

3.为避免溢出,目标指向的数组的大小应 足够长,以包含与源相同的 C 字符串(包括终止空字符),并且不应在内存中与源重叠。
4.目标空间必须可变。
char* str = "**********";//str为常量字符串,不可修改
char* p = "hello csdn";strcpy(str, p);//目标不可修改,故strcpy使用非法

用例:

/* strcpy example */
#include <stdio.h>
#include <string.h>int main ()
{char str1[]="Sample string";char str2[40];char str3[40];strcpy (str2,str1);strcpy (str3,"copy successful");printf ("str1: %s\nstr2: %s\nstr3: %s\n",str1,str2,str3);return 0;
}

样例输出:

strcat

用法:

strcat:将源字符串的副本追加到目标字符串。

目标中的终止空字符 '\0' 被源的第一个字符覆盖,并且在目标中由两者串联形成的新字符串的末尾包含一个空字符 ' \0' 。

返回值:目标空间的起始地址。

注意:

1.源字符串必须以 '\0' 结束。
2.目标空间必须有足够的大,能容纳下源字符串的内容。
3.目标空间必须可修改。
4.字符串无法自己给自己追加。

用例:

/* strcat example */
#include <stdio.h>
#include <string.h>int main ()
{char str[80];strcpy (str,"these ");strcat (str,"strings ");strcat (str,"are ");strcat (str,"concatenated.");puts (str);return 0;
}

样例输出:

strcmp

用法:

strcmp:将 C 字符串 str1 与 C 字符串 str2 进行比较。

此函数开始比较每个字符串的第一个字符。如果它们彼此相等,则继续以下对比,直到字符不同或达到终止空字符。

返回值:

三、长度受限制的字符串函数介绍

strncpy

用法:

strncpy:从字符串中复制字符。

source 的第一个字符数复制到 destination 。如果在复制 num 个字符之前找到源 C 字符串的末尾(由 null 字符表示),则目标将填充零,直到总共写入 num 个字符为止。

如果源长度超过 num,则不会在目标末尾隐式附加空字符。因此,在这种情况下,不应将目标视为以空结尾的 C 字符串(这样读取它会溢出)。

目的地和来源不得重叠。

返回值:目标空间的起始地址。

注意:

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

用例:

/* strncpy example */
#include <stdio.h>
#include <string.h>int main ()
{char str1[]= "To be or not to be";char str2[40];char str3[40];/* 复制到大小缓冲区: */strncpy ( str2, str1, sizeof(str2) );/* 部分副本(仅五个字符): */strncpy ( str3, str2, 5 );str3[5] = '\0';   /* 手动添加空字符 */puts (str1);puts (str2);puts (str3);return 0;
}

样例输出:

strnact

用法:

strncat:从字符串追加字符。

将源的首 num 个字符追加到目标,外加一个终止空字符。

如果源中 C 字符串的长度小于 num,则仅复制终止空字符之前的内容。

返回值:目标空间的起始地址。

用例:

/* strncat example */
#include <stdio.h>
#include <string.h>int main ()
{char str1[20];char str2[20];strcpy (str1,"To be ");strcpy (str2,"or not to be");strncat (str1, str2, 6);puts (str1);return 0;
}

样例输出: 

strncmp

用法:

strncmp:比较两个字符串的字符。

将 C 字符串 str1 的 num 个字符与 C 字符串 str2 的 num 个字符进行比较。
此函数开始比较每个字符串的第一个字符。如果它们彼此相等,则继续使用以下对,直到字符不同,直到达到终止的空字符,或者直到两个字符串中的 num 字符匹配,以先发生者为准。

返回值:

字符串查找

strstr

用法:

strstr:查找子字符串。

返回指向 str1 中第一次出现的 str2 的指针,如果 str2 不是 str1 的一部分,则返回一个空指针。

匹配过程不包括终止空字符,但它到此为止。

返回值:指向 str2 中指定的整个字符序列在 str1 中首次出现的指针,如果序列在 str1 中不存在,则为 null 指针。

用例:

#include<stdio.h>
#include<string.h>
int main()
{char str1[] = "Hello CSDN!";char str2[] = "He";char* tmp = strstr(str1, str2);if (tmp == NULL){printf("str2不是str1的一部分。");}else{printf("str2是str1的一部分。");}return 0;
}

样例输出:

strtok

用法:

strtok:将字符串拆分为 tokens

对此函数的一系列调用将 str 拆分为标记,这些标记是由分隔符中的任何字符分隔的连续字符序列。

在第一次调用时,该函数需要一个 C 字符串作为 str 的参数,其第一个字符用作扫描 token 的起始位置。在后续调用中,该函数需要一个空指针,并使用最后一个 token 末尾之后的位置作为扫描的新起始位置。

为了确定一个 token 的开头和结尾,该函数首先从起始位置扫描分隔符中未包含的第一个字符(该字符将成为 token 的开头)。然后从 token 的开头开始扫描分隔符中包含的第一个字符,该字符将成为令牌的末尾。如果找到终止空字符,扫描也会停止。

token 的此结尾将自动替换为空字符,并且 token 的开头由函数返回。

一旦在对 strtok 的调用中找到 str 的终止空字符,则对此函数的所有后续调用(以空指针作为第一个参数)都将返回空指针。

找到最后一个 token 的点由要在下一次调用中使用的函数在内部保留(不需要特定的库实现来避免数据争用)。

返回值:

如果找到 token ,则指向 token 开头的指针。                                                                                否则为 null 指针。
当在正在扫描的字符串中到达字符串的末尾(即空字符)时,始终返回空指针。

注意:

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

用例:

int main()
{char str[] = "https://gitee.com/bright-and-sparkling-at-night"; //需要断开的语句char ret[50];//用来临时存放str的数组strcpy(ret, str);char* sep = ":/.";//分隔符集合char* tmp = NULL;for ( tmp = strtok(ret,sep); tmp != NULL; tmp = strtok(NULL, sep)){printf("%s\n", tmp);}return 0;
}

样例输出:

四、内存函数

memcpy

用法:

memcpy:复制内存块

num 的字节的值从 source 指向的位置直接复制到 destination 指向的内存块。

返回值:目标空间的起始地址。

注意: 

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

用例:

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

样例输出:



memmove

用法:

memmove: 移动内存块

num 个字节的值从 source 指向的位置复制到 destination 指向的内存块。复制就像使用了中间缓冲区一样,允许目标和源重叠。 

返回值:目标空间起始地址。

注意:

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

用例:

#include<stdio.h>
#include<string.h>int main()
{char str[] = "memmove can be very useful......";memmove(str + 20, str + 15, 11);puts(str);return 0;
}

样例输出: 

memcmp

用法:

memcmp: 比较两个内存块

ptr1 指向的内存块的前 num 字节数与 ptr2 指向的第一个字节数进行比较,如果它们都匹配,则返回零,如果不匹配,则返回一个不同于零的值,表示哪个更大。

返回值:

注意:

1. memcmp 比较的数据是以 byte 为单位的,我们需要考虑到数据的存储

2. 与 strcmp 不同,该函数在找到空字符后不会停止比较。

memset

用法:

memset:填充内存块 

ptr 指向的内存块的第一个字节数设置为指定值(解释为无符号字符)。

注意:

memset 填充数据是以 byte 为单位,如果需要填充的数据为 int 型,则要考虑数据在内存中的存储

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

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

相关文章

Vue系列(三)之 基础语法下篇【事件处理,表单综合案例,组件通信】

一. 事件处理 在 Vue.js 中&#xff0c;v-on 指令被用于监听 DOM 事件&#xff0c;并在事件触发时执行相应的方法&#xff0c;这些方法就是事件处理器。v-on 指令有简写形式 &#xff0c;例如 click"handleClick" 会监听点击事件并执行 handleClick 方法。 事件处理…

1小时掌握Python操作Mysql数据库之pymysql模块技术

大家好&#xff0c;我是python222小锋老师。前段时间卷了一套 Python3零基础7天入门实战 近日锋哥又卷了一波课程&#xff0c;Python操作Mysql数据库的pymysql技术&#xff0c;文字版视频版。1小时掌握。 视频版教程 1小时掌握Python操作Mysql数据库之pymysql模块技术 文字版…

RHCSA_Linux 从命令行管理文件

目录 一、文件命令规范&#xff1a; 二、创建链接文件 1、创建软链接文件 2、创建硬链接文件 三、目录操作命令 1、创建目录 -- mkdir 2、统计目录及文件的空间占用情况 -- du 3、删除目录文件 四、创建、删除普通文件 1、创建普通文件 2、删除普通文件 五、数据流和…

golang实现远程控制主机

文章目录 ssh原理使用golang远程下发命令使用golang远程传输文件 ssh原理 说到ssh原理个人觉得解释最全的一张图是这张华为画的 Connection establishment 这一步就是建立tcp连接 version negotiation 这一步是ssh客户端(连接者)和被ssh服务端(连接者)进行协议的交换&#xf…

Redis桌面管理工具Redis Desktop Manager mac中文版功能特色

Redis Desktop Manager for Mac是一款实用的Redis可视化工具。RDM支持SSL / TLS加密&#xff0c;SSH隧道&#xff0c;基于SSH隧道的TLS&#xff0c;为您提供了一个易于使用的GUI&#xff0c;可以访问您的Redis数据库并执行一些基本操作&#xff1a;将键视为树&#xff0c;CRUD键…

Springboot整合分页插件pagehelper

首先需要有一定的springbootmybatis的基础&#xff0c;才能使用顺畅 项目结构如下 引入依赖&#xff0c;springboot版本选的是2.7.16版本&#xff0c;jdk选的17&#xff0c; <!--分页插件--> <dependency><groupId>com.github.pagehelper</groupId><…

静态通讯录

今天我们分享一下静态通讯录详细解释和代码&#xff0c;之前分享过的只是通讯录的代码&#xff0c;但是我们没有进行讲解和解释&#xff0c;今天我们一边分享它的代码一边解释原因&#xff0c;让大家可以手撕通讯录。现在开始我们的学习吧。 首先我们应该要有三个文件&#xf…

java面试题-jvm基础知识

1 JVM组成 1.1 JVM由那些部分组成&#xff0c;运行流程是什么&#xff1f; 难易程度&#xff1a;☆☆☆ 出现频率&#xff1a;☆☆☆☆ JVM是什么 Java Virtual Machine Java程序的运行环境&#xff08;java二进制字节码的运行环境&#xff09; 好处&#xff1a; 一次编写&a…

计算机丢失msvcp140_1.dll的解决办法,丢失msvcp140_1.dll的原因

丢失 msvcp140_1.dll 是一个常见的错误信息&#xff0c;通常会在尝试运行某些程序时出现。msvcp140_1.dll 是一个动态链接库文件&#xff0c;它包含了许多 C标准库函数的实现&#xff0c;这些函数在许多程序中都是必需的。因此&#xff0c;如果丢失了该文件&#xff0c;程序可能…

微软最热门的10款前端开源项目!

本文来盘点微软开源的十大前端项目&#xff0c;这些项目在 Github 上获得了超过 45 万 Star&#xff01; Visual Studio Code Visual Studio Code 是一款由微软开发的开源的代码编辑器。它支持多种编程语言&#xff0c;如C、C、C#、Python、JavaScript 和 TypeScript 等&…

记一次linux下pip安装包时出错及奇怪的解决过程

一、问题说明 如图&#xff0c;在使用pip安装测速工具speedtest-cli时&#xff0c;终端提示“Externally managed environment &#xff08;从外部管理的环境&#xff09;”&#xff0c;导致无法安装该库。 二、问题解决 1 尝试提示的解决方案&#xff0c;改用命令apt inst…

c++获取当前时间的字符串

代码 void getNowTimePrefix(std::string& prefix) {std::time_t nowTime;struct tm* p new tm;std::time(&nowTime);localtime_s(p, &nowTime);int year p->tm_year 1900;int month p->tm_mon 1;int day p->tm_mday;int hour p->tm_hour;int …

机器学习算法基础--逻辑回归

目录 1.数据收集及处理 2.数据提取及可视化 3.逻辑回归训练样本并且测试 4.绘制散点决策边界 逻辑回归的方法已经在数学建模里面讲过了&#xff0c;这里就不多讲了。 本篇我们主要是利用逻辑回归的方法来求解分类问题。 1.数据获取及处理 import pandas as pd from sklearn…

计算机竞赛 深度学习YOLO抽烟行为检测 - python opencv

文章目录 1 前言1 课题背景2 实现效果3 Yolov5算法3.1 简介3.2 相关技术 4 数据集处理及实验5 部分核心代码6 最后 1 前言 &#x1f525; 优质竞赛项目系列&#xff0c;今天要分享的是 &#x1f6a9; 基于深度学习YOLO抽烟行为检测 该项目较为新颖&#xff0c;适合作为竞赛课…

《Kubernetes部署篇:Ubuntu20.04基于外部etcd+部署kubernetes1.25.14集群(多主多从)》

一、部署架构图 1、架构图如下所示: 2、部署流程图如下所示: 二、环境信息 1、资源下载基于外部etcd+部署容器版kubernetes1.25.14集群资源合集 2、部署规划主机名K8S版本系统版本内核版本IP地址备注k8s-master-121.25.14Ubuntu 20.04.5 LTS5.15.0-69-generic192.168.1.12ma…

[Hadoop] start-dfs.sh ssh报错

Permission denied (publickey 决解方案 相关命令 cd ~/.sshssh-keygen -t rsa -p""cat id_rsa.pub >> authorized_keyschmod 0600 authorized_keys 相关链接Hadoop: start-dfs.sh permission denied - Stack Overflow Java HotSpot(TM) Server VM warning…

深度学习-一个简单的深度学习推导

文章目录 前言1.sigmod函数2.sigmoid求导3.损失函数loss4.神经网络1.神经网络结构2.公式表示-正向传播3.梯度计算1.Loss 函数2.梯度1.反向传播第2-3层2.反向传播第1-2层 3.python代码 前言 本章主要推导一个简单的两层神经网络。 其中公式入口【入口】 1.sigmod函数 激活函数…

idea创建springboot项+集成阿里连接池druid

创建项目并集成流程 1&#xff1a;前提准备2&#xff1a;创建springboot项目流程3&#xff1a;集成阿里连接池步骤4&#xff1a;集成swagger方便测试5&#xff1a;书写增删改查进行测试6&#xff1a;项目gitee地址 1&#xff1a;前提准备 准备开发工具&#xff1a;idea java环…

世界前沿技术发展报告2023《世界信息技术发展报告》(三)量子信息技术

&#xff08;三&#xff09;量子信息技术 1. 概述2. 量子计算2.1 阿里巴巴达摩院成功研制两比特量子芯片&#xff0c;单比特操控精度超99.97%2.2 加拿大Xanadu公司开发出可编程光量子计算机2.3 美国英伟达公司为经典-量子混合计算推出开发架构2.4 日本国家自然科学研究所开发出…

9+单细胞+实验验证,探讨单基因对癌细胞转移作用的思路方向

今天给同学们分享一篇单细胞实验的生信文章“Identification of RAC1 in promoting brain metastasis of lung adenocarcinoma using single-cell transcriptome sequencing”&#xff0c;这篇文章于2023年5月18日发表在Cell Death Dis期刊上&#xff0c;影响因子为9。 本研究旨…