C语言:字符函数和字符串函数(一篇拿捏字符串函数!)

news2024/9/24 1:22:35

目录

求字符串长度:

1. strlen(字符串长度)

长度不受限制函数:

2. strcpy(字符串拷贝)

3. strcat(字符串追加)

4. strcmp(字符串比较)

长度受限制函数:

5. strncpy(字符串拷贝)

6. strncat(字符串追加)

7. strncmp(字符串比较)

字符串查找:

8. strstr(查找字符串子串)

9. strtok(字符串分割)

错误信息报告:

10. strerror(返回错误信息)

字符操作函数:

字符转换:

1. tolower(小写->大写)

2. toupper(大写->小写)

内存操作函数:

1. memcpy(内存拷贝)

2. memmove(内存拷贝)

3. memcmp(内存比较)

4. memset(内存设置)


求字符串长度:

1. strlen(字符串长度)

size_t   strlen ( const char * str );
        str:C 字符串。
返回值:unsigned  int.
1.1 字符串已经 '\0' 作为结束标志 strlen 函数返回的是在字符串中 '\0' 前面出现的字符个数 (不包
含 '\0' )。
1.2 参数指向的字符串必须要以 '\0'结束
1.3 注意函数的返回值为size_t ,是无符号的( 易错 )。
#include <stdio.h>
#include <string.h>

int main()
{
	if ((int)strlen("abc") - (int)strlen("abcdef") > 0)
	{
		printf("大于\n");
	}
	else
	{
		printf("小于等于\n");
	}

	return 0;
}

长度不受限制函数:

2.strcpy(字符串拷贝)

char*  strcpy(char * destination, const char * source );
        destinatiob:指向要在其中复制内容的目标 数组的指针
        source:要复制的 C 字符串。
2.1 源字符串必须以 '\0' 结束。
2.2 会将源字符串中的 '\0' 拷贝到目标空间。
2.3 目标空间必须足够大,以确保能存放源字符串。
2.4 目标空间必须可变。
#include <stdio.h>
#include <string.h>

int main()
{
	//char arr1[3] = "";
	//char arr2[] = "hello bit";
	char* arr1 = "xxxxxxxxxx";
	char arr2[6] = { 'a', 'b', 'c', 'd', 'e' , '\0'};
	strcpy(arr1, arr2);
	printf("%s\n", arr1);

	return 0;
}

3.strcat(字符串追加)

char * strcat ( char * destination, const char * source );
        
         destination:指向目标数组的指针,该数组应包含 C 字符串,并且足够大以包含串联的结果字符串。
        source: 要追加的 C 字符串。这不应与 目标 重叠。
3.1 源字符串必须以 '\0' 结束。
3.2 目标空间必须有足够的大,能容纳下源字符串的内容。
3.3 目标空间必须可修改。
#include <stdio.h>
#include <string.h>

int main()
{
	char arr1[20] = "hello ";
	char arr2[] = "world";
	strcat(arr1, arr2);

	printf("%s\n", arr1);
	return 0;
}

4. strcmp(字符串比较)

int strcmp ( const char * str1, const char * str2 );
        
         str1:要比较的 C1 字符串。
         str2:要比较的 C2 字符串。
4.1 标准规定:
        4.1.1 第一个字符串大于第二个字符串,则返回大于 0 的数字
        4.1.2 第一个字符串等于第二个字符串,则返回0
        4.1.3 第一个字符串小于第二个字符串,则返回小于 0 的数字
#include <stdio.h>
#include <string.h>

int main()
{
	int ret = strcmp("bbq", "bcq");
	if (ret>0)
		printf(">\n");

	printf("%d\n", ret);
	return 0;
}

长度受限制函数:

5. strncpy(字符串拷贝)

char * strncpy ( char * destination, const char * source, size_t num );
        
         destination:指向要在其中复制内容的目标数组的指针。
         source:要复制的 C 字符串。
         num :要从 复制的最大字符数;

                  size_t 是无符号整数类型。

5.1 拷贝 num 个字符从源字符串到目标空间
5.2 如果源字符串的长度小于 num,则拷贝完源字符串之后,在目标的后边追加0,直到num
#include <stdio.h>
#include <string.h>

int main()
{
	char arr1[20] = "abcdef";
	char arr2[] = "xxx";
	strncpy(arr1, arr2, 5);

	return 0;
}

6. strncat(字符串追加)

char * strncat ( char * destination, const char * source, size_t num );
        
         destination:指向目标数组的指针,该数组应包含一个 C 字符串,并且足够大以包含串联的结果字符串,包括其他 null 字符。
        source:要追加的 C 字符串。
         num: 要追加的最大字符数。

                 size_t是无符号整数类型。

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

int main()
{
	char arr1[20] = "abcdef\0yyyyyyyy";
	char arr2[] = "xxxxxxxxx";
	strncat(arr1, arr2, 3);

	return 0;
}

7. strncmp(字符串比较)

int strncmp ( const char * str1, const char * str2, size_t num );
        
         str1:要比较的 C1 字符串。
        str2:要比较的 C2 字符串。
        num:要比较的最大字符数。
                 size_t是无符号整数类型。
7.1 比较到出现另个字符不一样或者一个字符串结束或者num个字符全部比较完

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

int main()
{
	char arr1[] = "abcqwertyuiop";
	char arr2[] = "abcdef";
	printf("%d\n", strncmp(arr1, arr2, 4));

	return 0;
}

字符串查找:

8. strstr(查找字符串子串)

char * strstr ( const char *str1, const char * str2);
        
         str1:要扫描的 C 字符串。
         str2:包含要匹配的字符序列的 C 字符串。
#include <stdio.h>
#include <string.h>

int main()
{
	char arr1[] = "abbbcdef";
	char arr2[] = "bbc";

	char* ret = strstr(arr1, arr2);
	if (ret != NULL)
		printf("%s\n", ret);
	else
		printf("找不到\n");

	return 0;
}

9. strtok(字符串分割)

char * strtok ( char * str, const char * sep );
        
         str:要截断的 C 字符串。请注意,此字符串是通过分解为较小的字符串(标记)来修改的。或者,可以指定空指针,在这种情况下,函数将继续扫描以前成功调用函数的位置。
        sep :包含分隔符字符的 C 字符串。这些可能因调用而异。
9.1 sep 参数是个字符串,定义了用作分隔符的字符集合。
9.2 第一个参数指定一个字符串,它包含了 0 个或者多个由 sep 字符串中一个或者多个分隔符分割的标记。
9.3 strtok函数找到str中的下一个标记,并将其用 \0 结尾,返回一个指向这个标记的指针。 (注:
strtok 函数会改变被操作的字符串,所以在使用 strtok 函数切分的字符串一般都是临时拷贝的内容
并且可修改。)
9.4 strtok 函数的第一个参数不为 NULL ,函数将找到 str 中第一个标记, strtok 函数将保存它在字符串中的位置。
9.5 strtok 函数的第一个参数为 NULL ,函数将在同一个字符串中被保存的位置开始,查找下一个标记。
9.6 如果字符串中不存在更多的标记,则返回 NULL 指针
#include <stdio.h>
#include <string.h>

int main()
{
	char arr[] = "zpengwei@yeah.net@666#777";
	char copy[30];
	strcpy(copy, arr);

	char sep[] = "@.#";
	char* ret = NULL;

	for (ret = strtok(copy, sep); ret != NULL; ret=strtok(NULL, sep))
	{
		printf("%s\n", ret);
	}

	return 0;
}

错误信息报告:

10. strerror(返回错误信息)

char * strerror ( int errnum );
        
         errnum :错误号。
        库函数在执行的时候,发生了错位会将一个错误码存放errno这个变量中errno是C语言提供的一个全局的变量。
10.1 返回错误码,所对应的错误信息。 
#include <stdio.h>
#include <string.h>

int main()
{
	int i = 0;
	for (i = 0; i < 10; i++)
	{
		printf("%d: %s\n", i, strerror(i));//
	}
	return 0;
}

字符操作函数:

字符串函数
函数
如果他的参数符合下列条件就返回真
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
任何可打印字符,包括图形字符和空白字

字符转换:

1.towlower(小写->大写)

int  tolower ( int c );

        

        c:要转换、转换为 int 或 EOF 的字符。

#include <stdio.h>
#include <ctype.h>

int main()
{
    printf("%c\n", tolower('A'));
    printf("%c\n", tolower('s'));
    
    return 0;
}

2. toupper(大写->小写)

int  toupper ( int c );

        

        c:要转换、转换为 int 或 EOF 的字符。

#include <stdio.h>
#include <ctype.h>

int main()
{
	char arr[20] = { 0 };
	gets(arr);//遇到空格继续读

	char* p = arr;
	while (*p)
	{
		if (isupper(*p))// *p>='A' && *p<='Z'
		{
			*p = tolower(*p);//*p = *p+32;
		}
		p++;
	}
	printf("%s\n", arr);
	return 0;
}

内存操作函数:

1. memcpy(内存拷贝)

void * memcpy ( void * destination, const void * source, size_t num );
        
         destination:指向要在其中复制内容的目标数组的指针,类型转换为 void* 类型的指针。
        source:指向要复制的数据源的指针,类型转换为 const void* 类型的指针。
        num :要复制的字节数。
                    size_t 是无符号整数类型。
1.1 函数 memcpy source的位置开始向后复制num字节的数据到destination 的内存位置
1.2 这个函数在遇到 '\0' 的时候并 不会 停下来
1.3 如果 source destination 有任何的 重叠 复制的结果都是未定义的。

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

int main()
{
	int arr1[] = { 1,2,3,4,5,6,7,8,9,10 };
	int arr2[20] = { 0 };
	//将arr1中的内容,拷贝到arr2中
	memcpy(arr2, arr1, 40);
         int*  int*
	int i = 0;
	for (i = 0; i < 20; i++)
	{
		printf("%d ", arr2[i]);
	}

	return 0;
}

2. mommove(内存拷贝)

void * memmove ( void * destination, const void * source, size_t num );
        
         destination:指向要在其中复制内容的目标数组的指针,类型转换为 void* 类型的指针。
        source:指向要复制的数据源的指针,类型转换为 const void* 类型的指针。
        num : 要复制的字节数。

                  size_t 是无符号整数类型。

2.1 memcpy差别就是memmove 函数处理的源内存块和目标内存块是可以重叠的。
2.2 如果源空间和目标空间出现重叠,就得使用 memmove 函数处理。
#include <stdio.h>
#include <string.h>

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

3. memcmp(内存比较)

int  memcmp ( const void * ptr1, const void * ptr2, size_t num );
        
         ptr1:指向内存块的指针。
        ptr2:指向内存块的指针。
         num :要比较的字节数。
3.1 比较从 ptr1 ptr2 指针开始的 num个字节;
3.2 返回值如下:

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

int main()
{
	int arr1[] = { 1,2,1,4,5,6 };
	int arr2[] = { 1,2,257 };
	int ret = memcmp(arr1, arr2, 10);
	printf("%d\n", ret);
	return 0;
}

4. memset(内存设置)

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

        

        ptr1:指向要填充的内存块的指针。

        value:要设置的值。该值作为 int 传递,但该函数使用此无符号 char 转换填充内存块。

        num :要设置为该值的字节数。
                    size_t 是无符号整数类型。

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

int main()
{
	char arr[] = "hello bit";
	memset(arr+1,'x',4);//以字节为单位设置的
	printf("%s\n", arr);
	return 0;
}

以上就是个人学习见解和学习的解析,欢迎各位大佬在评论区探讨!

感谢大佬们的一键三连! 感谢大佬们的一键三连! 感谢大佬们的一键三连!

                                              

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

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

相关文章

关于大学考研与不考研自己一点看法

据网上报道&#xff0c;2023年研究生报考人数为474万&#xff0c;相较22年报名人数457万人,同比增长 17 万 2023年的考研录取率为20&#xff05;,如今,在北京的硕士博士生超过本科生人数 学历的贬值&#xff0c;通胀,速度远远超乎了想象 近几年的考研热,考公,考编热是年年基本上…

完美解决xinput1_3.dll丢失问题,修复xinput1_3.dll文件

在电脑游戏中经常遇到xinput1_3.dll丢失的问题&#xff0c;这个问题是因为系统缺少该文件而引起的。而且&#xff0c;这个问题很容易导致游戏无法正常运行&#xff0c;给玩家带来很大的烦恼。在本文中&#xff0c;我们将详细介绍如何修复这个问题&#xff0c;给大家详细的说明多…

YOLO目标检测——时间检测数据集下载分享

时间数据集是表示一天中不同时间的图像集合&#xff0c;日出和日落被视为同一类别。数据集包含日出/日落、白天场景和夜间场景的图像&#xff0c;并已重新缩放为 224 x 224 x 3 像素&#xff0c;描绘了不同的地点和不同的天气条件&#xff0c;如晴朗的天空&#xff0c;阴天等。…

Chrome自动升级了,找不到最新版本的webdriver怎么办?

Chrome自动升级了,找不到最新版本的webdriver怎么办? 背景解决办法 背景 我用Selenium开发了Facebook和Linkedin爬虫&#xff0c;有些新需求要调一下&#xff0c;今天启动selenium时有报错&#xff0c;报错如下&#xff1a;selenium.common.exceptions.SessionNotCreatedExce…

pygame实现物体运动拖尾尾迹-渐隐版

解说文案&#xff1a; 视频讲解&#xff1a;https://www.bilibili.com/video/BV14w411S74E/ 上一集我们实现了物体本体形式的拖尾&#xff0c;这一集我们基于上一集来实现物体逐渐变透明到消失的拖尾。 上集我们也说过&#xff0c;逐渐变透明到消失的物体拖尾只不过是给物体…

Qt无边框青绿色主题

收费产品&#xff0c;学生党、闹眼子党勿扰 收费金额&#xff1a;500元 1 概述 最近因项目需要&#xff0c;写了一个炫酷的青绿色、无边框界面&#xff0c;和3DSMax的界面有点类似。 2 截图 首先看看3DSMax的界面 不知道大家看出来没&#xff0c;这个ui其实很简单&#xff…

15. Docker实战监控神器Uptime Kuma

目录 1、前言 2、什么是Uptime Kuma? 3、Docker部署Uptime Kuma 3.1、安装 3.2、访问 3.3、配置 3.4、集成飞书机器人 3.5、效果 1、前言 在利用Docker部署项目时&#xff0c;我们需要时刻知道已部署的容器的状态。且通常会把所有的站点监控配置到云平台上&#xff0c…

算法通关村十三关 | 辗转相除法、素数和丑数

1. 辗转相除法 辗转相除法又称欧几里得算法&#xff0c;求两个数的最大公因数&#xff0c;希腊数学家喜欢用图形来处理问题&#xff0c;于是将要求最大公约数问题转化为&#xff0c;以两个数字构成矩形&#xff0c;寻找可以铺满整个矩形的最大正方形的边长问题。 题目 例如8和1…

基于Spring Boot的企业门户网站设计与实现(Java+spring boot+MySQL)

获取源码或者论文请私信博主 演示视频&#xff1a; 基于Spring Boot的企业门户网站设计与实现&#xff08;Javaspring bootMySQL&#xff09; 使用技术&#xff1a; 前端&#xff1a;html css javascript jQuery ajax thymeleaf 微信小程序 后端&#xff1a;Java springboot…

<Xilinx AXI4> AXI4_Full(一)总线说明

目录 01 AXI4-Full Brust传输介绍 write burst transcation read burst transcation 02 AXI4_Full读写事务接口说明 写事务(Write transaction) AXI4-Full_master写事务逻辑信号 AXI4-Full_slave写事务逻辑信号 读事务(Read transaction) AXI4-Full_master读事务逻辑信…

删除、移动、复制文件时总是要卡在99%一段时间解决方法

Win10文件夹重命名、移动、删除等操作卡顿3-5秒。 原因分析: 查看发现&#xff0c;卡顿期间资源管理器无响应&#xff0c;并且其高度占用CPU资源&#xff0c;但是对于非文件夹文件操作没有问题。 解决方案: 1、双击“此电脑”&#xff0c;选择“查看”&#xff0c;再选择“选…

基于 Spring 前后端分离版本的论坛系统

访问地址:http://8.130.142.126:18080/sign-in.html 代码获取:基于 Spring 前后端分离版本的论坛系统: 基于 Spring 前后端分离版本的论坛系统 一.前置知识 1.软件生命周期 a. 可行性研究&#xff1a;通过分析软件开发要求&#xff0c;确定软件项目的性质、目标和规模&am…

苹果电脑同时使用内外网

公司用的有线的内网&#xff0c;自己要用无线的外网。插上网线就不能用wifi&#xff0c;很烦。于是学到了一种插上网线也能使用wifi的方法。 第一步&#xff0c;调整wifi和网线的顺序 系统偏好设置-网络-左下角设定服务顺序&#xff0c;把wifi调到有线网络前面。 第二步&…

盘点2023最新国内SaaS系统TOP20排名,中国的SaaS系统有未来吗?

在SaaS系统飞速发展的2023年&#xff0c;国内涌现出了一大批优秀的SaaS系统公司&#xff0c;都有哪些企业位列其中呢&#xff1f;SaaS系统有着什么样独特的竞争力&#xff0c;能够不断发展&#xff0c;成为目前市面上发展的较好的云服务框架&#xff1f;SaaS究竟是什么&#xf…

21.3 CSS 背景属性

1. 背景颜色 background-color属性: 设置元素的背景颜色. 它可以接受各种颜色值, 包括命名颜色, 十六进制颜色码, RGB值, HSL值等.快捷键: bctab background-color:#fff;<!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"…

微芯I/O控制器瞄准工业与嵌入式运算应用

微芯科技(Microchip Technology)日前发布SCH322X系列I/O控制器新品&#xff0c;该系列产品基于工业及嵌入式开发工程师的需求而开发&#xff0c;功能丰富且具高灵活性。新一代I/O控制器系列拥有尺寸更小的包装和更长的产品生命周期&#xff0c;可运用于更多经济型工业及嵌入式开…

DSP_TMS320F28377D_算法加速方法3_使用TMU库加速

继上两篇方法 DSP_TMS320F28377D_算法加速方法1_拷贝程序到RAM运行_江湖上都叫我秋博的博客-CSDN博客 DSP_TMS320F28377D_算法加速方法2_添加浮点运算快速补充库rts2800_fpu32_fast_supplement.lib_江湖上都叫我秋博的博客-CSDN博客 之后&#xff0c;本文继续讨论第三种DSP算法…

Google Pay外包开发流程

集成 Google Pay 可以为你的应用提供方便的支付体验。下面是一个简要的 Google Pay 集成流程概述&#xff0c;希望对大家有所帮助。北京木奇移动技术有限公司&#xff0c;专业的软件外包开发公司&#xff0c;欢迎交流合作。 1.创建 Google 开发者账号&#xff1a; 如果你还没有…

激活函数总结(二十六):激活函数补充(Probit、Smish)

激活函数总结&#xff08;二十六&#xff09;&#xff1a;激活函数补充 1 引言2 激活函数2.1 Probit 激活函数2.2 Smish 激活函数 3. 总结 1 引言 在前面的文章中已经介绍了介绍了一系列激活函数 (Sigmoid、Tanh、ReLU、Leaky ReLU、PReLU、Swish、ELU、SELU、GELU、Softmax、…

CUDA小白 - NPP(2) - Arithmetic and Logical Operations(1)

cuda小白 原文链接 NPP GPU架构近些年也有不少的变化&#xff0c;具体的可以参考别的博主的介绍&#xff0c;都比较详细。还有一些cuda中的专有名词的含义&#xff0c;可以参考《详解CUDA的Context、Stream、Warp、SM、SP、Kernel、Block、Grid》 常见的NppStatus&#xff0c…