字符串函数

2023-09-17 11:36:10

目录

一、求字符串长度

strlen

用法:

注意:

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

strcpy

用法:

注意:

strcat

用法:

注意:

用例:

strcmp

用法:

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

strncpy

用法:

注意:

用例:

strnact

用法:

用例:

strncmp

用法:

字符串查找

strstr

用法:

用例:

strtok

用法:

注意:

用例:


一、求字符串长度

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;
}

输出样例:

更多推荐

rv1126之isp黑电平(BLC)校准!

前言:大家好,今天我们继续来讲解isp第二期内容,这期内容主要分三个部分:1、tunning的工作流程2、利用RKISP2.x_Tuner来创建tunning工程,并连接上rv1126开发板进行抓图3、BLC(黑电平校准)的原理和校准方法以及实战那对于RKISP2.x_Tuner的工具使用,这个在第一期的内容里面有详细

从零开始在树莓派上搭建WordPress博客网站并实现公网访问

文章目录序幕概述1.安装PHP2.安装MySQL数据库3.安装Wordpress4.设置您的WordPress数据库设置MySQL/MariaDB创建WordPress数据库5.WordPressconfiguration6.将WordPress站点发布到公网安装相对URL插件修改config.php配置7.支持好友链

php程序设计的基本原则

单一职责原则(SRP):一个类应该只有一个原因引起变化,即一个类应该只负责一项职责。classUser{private$name;private$email;publicfunction__construct($name,$email){$this->name=$name;$this->email=$email;}pu

HTML5 游戏开发实战 | 俄罗斯方块

俄罗斯方块是一款风靡全球的电视游戏机和掌上游戏机游戏,它曾经造成的轰动与造成的经济价值可以说是游戏史上的一件大事。这款游戏看似简单但却变化无穷,游戏过程仅需要玩家将不断下落的各种形状的方块移动、翻转,如果某一行被方块充满了,那就将这一行消掉;而当窗口中无法再容纳下落的方块时,就宣告游戏结束。可见俄罗斯方块的需求如下。(

AI+游戏线下沙龙活动暨COC上海城市开发者社区8月活动

引言近年来,随着人工智能技术的不断发展和游戏开发技术的不断更新,越来越多的游戏公司开始将人工智能技术应用于游戏领域,以提高开发效率、降低成本,实现游戏玩家更好的游戏体验。为了探讨AI+游戏的技术实践经验,近日在亚马逊会议中心举办了一场以AI+游戏为主题的技术研讨会。在AI+游戏的技术实践研讨会上,与会者们分享了一些关于

云游戏下,会带来哪些技术变革

云游戏前言元宇宙是什么?云游戏的福利云游戏包括哪些技术前言大家好,在这里给大家介绍一个新名词----云游戏。可能有一些小伙伴了解过一些,也有一些小伙伴可能没有了解过,那这里就带大家了解一下元宇宙里的云游戏。2023年,如果说到什么最火🔥,什么最流行,那肯定是非元宇宙莫属了。自从2021年来,元宇宙就如同那雨后春笋一样

方案:数智化视频AI技术为智慧防汛筑基,构建防汛“数字堤坝”

一、背景分析在过去的几年中,全球气候变化导致许多城市在雨季面临严重的洪涝灾害。这些灾害不仅对人们的生命安全和财产造成威胁,也影响了城市的正常运转。传统的防汛手段主要依赖人力监控和应急指挥,但存在响应速度慢、处理效率低等问题。因此,我们需要一种智能、高效的解决方案来提高防汛效率和降低洪涝灾害的影响。随着新一代信息技术的普

【JavaSE专栏49】Java集合类LinkedList解析,链表和顺序表有什么不同?

作者主页:Designer小郑作者简介:3年JAVA全栈开发经验,专注JAVA技术、系统定制、远程指导,致力于企业数字化转型,CSDN学院、蓝桥云课认证讲师。主打方向:Vue、SpringBoot、微信小程序本文讲解了Java中集合类LinkedList的语法、使用说明和应用场景,并给出了样例代码。目录一、什么是Lin

[C++入门]---List的使用及模拟实现

文章目录1.list的介绍2.list的使用2.1list的构造函数2.2listmodifiers2.3listcapacity2.4listelmentaccess2.5iterator的使用3.list的模拟实现3.1list的源码1.list的介绍list是可以在常数范围内在任意位置进行插入和删除的序列式容器,

【Java 基础篇】深入理解Java HashMap:使用注意事项和性能优化

Java是一种广泛使用的编程语言,而集合是Java编程中不可或缺的一部分。在Java的集合框架中,HashMap是一个常用的数据结构,用于存储键值对。本文将深入介绍HashMap集合,从基础到高级用法,帮助您更好地理解和利用它。什么是HashMap?HashMap是Java集合框架中的一个类,它实现了Map接口,用于存

求生之路2服务器搭建插件安装及详细的游戏参数配置教程windows

求生之路2服务器搭建插件安装及详细的游戏参数配置教程windows大家好我是艾西,最近研究了下l4d2(求生之路2)这款游戏的搭建以及架设过程。今天就给喜欢l4d2这款游戏的小伙伴们分享下怎么搭建架设一个自己的服务器。毕竟自己当服主是热爱游戏每一个人的梦想,在自己的服务器里为所欲为在游戏里成就自己。(注:因PT原因本文

热文推荐