C语言——字符函数与字符串函数

news2024/11/20 10:32:22

正文开始:在编程过程中,我们经常要处理字符和字符串,为了方便操作字符和字符串,C语⾔标准库中提供了 一系列库函数,接下来我们就学习⼀下这些函数。

1. 字符分类函数

C语⾔中有⼀系列的函数是专门做字符分类的,也就是⼀个字符是属于什么类型的字符的。
这些函数的使⽤都需要包含⼀个头⽂件是 ctype.h

 这些函数的使用方法⾮常类似,我们就讲解⼀个函数的事情,其他的⾮常类似:

 int islower ( int c );
//返回int类型
//判断c是否为小写字母
//为真则返回非0整数
练习:
写⼀个代码,将字符串中的小写字⺟转⼤写,其他字符不变。
#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<ctype.h>


int main() {
	char arr[] = "abdGysHJs";
	char c;
	int i = 0;
	while (arr[i]) {
		c = arr[i];
		if (islower(c))//判断是否为小写字母,为真则执行if语句
		{
			c -= 32;
			arr[i] = c;
		}
		i++;
	}
	printf("%s", arr);
	return 0;
}

2.字符转换函数

C语言提供了2个字符转换函数:
int tolower ( int c ); //将参数传进去的大写字母转小写
int toupper ( int c ); //将参数传进去的小写字母转大写
对于上面的函数,我们是利用大小写的ASCII码值差32,有了转换函数,我们就可以直接使用tolower转换。

试试看吧

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


int main() {
	char arr[] = "abdGysHJs";
	char c;
	int i = 0;
	while (arr[i]) {
		c = arr[i];
		if (islower(c))//判断是否为小写字母,为真则执行if语句
		{
			/*c -= 32;
			arr[i] = c;*/

			c = toupper(c);
			arr[i] = c;
		}
		i++;
	}
	printf("%s", arr);
	return 0;
}

3. strlen的使用和模拟实现

size_t strlen(const char* str);
注意:
  • strlen函数返回的是在字符串中 '\0' 前面出现的字符个数(不包 含 '\0' )。
  • 字符串以“\0”为结束标志
  • 参数指向的字符串必须要以 '\0' 结束
  • 注意函数的返回值(size_t),是无符号的
  • strlen函数需要包含头文件   <string.h>
  • 学会strlen的模拟实现
#include<stdio.h>
#include<string.h>


int main()
{
	char arr1[] = "abc";
	char arr2[] = "abcdef";
	if (strlen(arr1) > strlen(arr2)) {
		printf("arr1>arr2");
	}
	else {
		printf("arr1<arr2");
	}
	return 0;
}

strlen的函数实现

方法1:

#include<stdio.h>
//计数器方式
int str_char(const char* str)
{
	int count = 0;
	assert(str);
	while (*str)
	{
		count++;
		str++;
	}
	return count;
}


int main() {
	char arr1[] = "abc";
	int ret = str_char(arr1);
	printf("arr1的长度%d",ret);
	return 0;
}

方法2:

//不能创建临时变量计数器
int str_char(const char* str) {
		assert(str);
		if (*str == '\0')//判断是否为空
			return 0;
		else
			return 1 + str_char(str + 1);//这里运用了递归的思想,每次数组+1到函数里	
}

int main() {
	char arr1[] = "abc";
	int ret = str_char(arr1);
	printf("arr1的长度%d",ret);
	return 0;
}

方法3:

C语言详解指针-CSDN博客icon-default.png?t=N7T8https://blog.csdn.net/Asuku_/article/details/137690083之前学习的(数组-数组),在这里也可以发挥其作用

//指针-指针的⽅式
int str_char(char* s)
{
    assert(s);//这里的使用需要包含头文件<assert.h>,断言s是否为NULL
    char* p = s;
    while ((*p != '\0'))
        p++;
    return p - s;

}

int main() {
    char arr1[] = "abc";
    int ret = str_char(arr1);
    printf("arr1的长度%d",ret);
    return 0;
}

4. strcpy 的使用和模拟实现

char* strcpy(char * destination, const char * source );
  • 源字符串必须以 '\0' 结束。
  •  会将源字符串中的 '\0' 拷贝到目标空间。
  •  目标空间必须足够大,以确保能存放源字符串。
  •  目标空间必须可修改。
  •  学会模拟实现。

strcpy的模拟实现

#include<stdio.h>
#include<assert.h>

char* my_strcpy(char*dest,const char*src)
{
	assert(dest!=NULL);
	assert(src!=NULL);
	int sz = src[5] - src[0];
	for (int i = 0; i < sz;i++) {
		*dest = *src;
		dest++;
		src++;
	}
	return dest;
 }

int main()
{
	char arr1[5];
	char arr2[5] = "abcde";

	my_strcpy(arr1, arr2);

	return 0;
}

5. strcat 的使用和模拟实现

源字符串必须以 '\0' 结束。
目标字符串中也得有 \0 ,否则没办法知道追加从哪里开始。
目标空间必须有⾜够的大,能容纳下源字符串的内容。
目标空间必须可修改。
字符串自己给自己追加,如何?

strcat模拟实现

char* my_strcat(char* dest, const char* src)
 {
     char* ret = dest;
     assert(dest != NULL);
     assert(src != NULL);
     while (*dest)
   {
	dest++;         //找到dest的‘\0’
   }
     while ((*dest++ = *src++))
   {
	   ;
   }
   return ret;
}

6. strcmp 的使用

第⼀个字符串大于第二个字符串,则返回大于0的数字
第⼀个字符串等于第二个字符串,则返回0
第⼀个字符串小于第二个字符串,则返回小于0的数字
那么如何判断两个字符串? ⽐较两个字符串中对应位置上字符ASCII码值的大小。
strcmp函数的模拟实现:

strcmp模拟实现

int my_strcmp(const char* str1, const char* str2)
{
	int ret = 0;
	assert(src != NULL);
	assert(dest != NULL);
	while (*str1 == *str2)
	{
		if (*str1 == '\0')
			return 0;
		str1++;         //统计数组长度
		str2++;
	}
	return *str1 - *str2;
}

7. strncpy 函数的使用

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

对比strcpy函数,strncpy则多了size_t num;

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

8. strncat 函数的使用

char * strncat ( char * destination, const char * source, size_t num );
  • 将source指向字符串的前num个字符追加到destination指向的字符串末尾,再追加一个 \0 符。
  • 如果source 指向的字符串的长度小于num的时候,只会将字符串中到 \0 的内容追加到destination指向的字符串末尾。
/* 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);
	printf("%s\n", str1);
	return 0;
}

输出结果:   To be or not

9. strncmp函数的使用

int strncmp ( const char * str1, const char * str2, size_t num );
比较str1和str2的前num个字符,如果相等就继续往后比较,最多比较num个字⺟,如果提前发现不⼀ 样,就提前结束,大的字符所在的字符串大于另外⼀个。如果num个字符都相等,就是相等返回0.

10. strstr 的使用

char * strstr ( const char * str1, const char * str2);
  • 函数返回字符串str2在字符串str1中第一次出现的位置
  • 字符串的比较匹配不包含 \0 字符,以 \0 作为结束标志
    /* strstr example */
    #include <stdio.h>
    #include <string.h>
    int main()
    {
    	char str[] = "This is a simple\0 string";
    	char* pch;                  
    	pch = strstr(str, "simple");//存放simple以后的字符串,到\0停止
    	printf("%s\n", pch);
    	return 0;
    }

11. 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 arr[] = "192.168.6.111";
	char* sep = ".";
    char* str = NULL;
	for (str = strtok(arr, sep); str != NULL; str = strtok(NULL, sep))
		{         //在arr数组中找到 '.',返回 ( char* )该位置的指针
		          //    如果strtok函数第一个为NULL,则从该位置继续往后找
		printf("%s\n", str);
		}
	 return 0;
}

12. strerror 函数的使用

char * strerror ( int errnum );
strerror函数可以把参数部分错误码对应的错误信息的字符串地址返回来。
#include <errno.h>
#include <string.h>
#include <stdio.h>


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

下面就对应了各个错误:可以尝试尝试

No error
Operation not permitted
No such file or directory
No such process
Interrupted function call
Input/output error
No such device or address
Arg list too long
Exec format error
Bad file descriptor
No child processes

perror函数的使用

也可以了解⼀下perror函数,perror  函数相当于⼀次将上述代码中的第9行完成了,直接将错误信息打 印出来。perror函数打印完参数部分的字符串后,再打印一个冒号和一个空格,再打印错误信息
#include <stdio.h>
#include <string.h>
#include <errno.h>
int main()
 {
	 FILE * pFile;
	 pFile = fopen("unexist.ent", "r");
	 if (pFile == NULL)
	 perror("Error opening file unexist.ent");
	 return 0;
}

Error opening file unexist.ent: No such file or directory

oi!  点个赞走吧!!!

 

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

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

相关文章

基于ssm的智慧餐厅点餐管理系统设计与实现(java项目+文档+元)

风定落花生&#xff0c;歌声逐流水&#xff0c;大家好我是风歌&#xff0c;混迹在java圈的辛苦码农。今天要和大家聊的是一款基于ssm的智慧餐厅点餐管理系统。项目源码以及部署相关请联系风歌&#xff0c;文末附上联系信息 。 项目简介&#xff1a; 智慧餐厅点餐管理系统设计…

在Mac主机上连接Linux虚拟机

前言 最近醉心于研究Linux&#xff0c;于是在PD上安装了一个Debian Linux虚拟机&#xff0c;用来练练手。但是每次在mac和Linux之间切换很是麻烦&#xff0c;有没有一种方法&#xff0c;可以在mac终端直接连接我的虚拟机&#xff0c;这样在mac终端上就可以直接操控我的Linux虚…

资本涌向AI,AI规模将达2205亿美元?

随着科技的飞速发展&#xff0c;全球科技巨头瑞银&#xff08;UBS&#xff09;在其最新报告中预测&#xff0c;科技产业正迎来一个前所未有的增长浪潮。特别是在人工智能&#xff08;AI&#xff09;领域&#xff0c;预计到2027年&#xff0c;AI模型和应用程序的市场规模将达到惊…

Docker部署WebRTC-Streamer

文章目录 WebRTC-Streamer概述Docker部署WebRTC-StreamerVue使用WebRTC-Streamer一些问题 WebRTC-Streamer概述 WebRTC-Streamer是一个基于WebRTC技术的流媒体传输工具&#xff0c;它可以通过Web浏览器实现实时音视频流的传输和播放。它提供了一种简单而强大的方式&#xff0c…

21.5k Star , AI 智能体项目OpenDevin:少写代码,多创造(附部署教程)

Aitrainee | 公众号&#xff1a;AI进修生 这是一个旨在复制 Devin 的开源项目&#xff0c;Devin 是一位自主人工智能软件工程师&#xff0c;能够执行复杂的工程任务并在软件开发项目上与用户积极协作。该项目致力于通过开源社区的力量复制、增强和创新 Devin。 Devin 代表了一…

汇舟问卷:国外问卷调查适合哪些人?

在这个快节奏的时代&#xff0c;朝九晚五的工作模式似乎已经成为许多人的固定生活模式。然而&#xff0c;这种日复一日的工作方式往往让人感到疲惫和厌倦&#xff0c;我们渴望找到一种既能赚钱又能兼顾生活的方式。 海外问卷调查作为一种适合在家做的赚钱方式&#xff0c;这两…

前端知识学习笔记-六(vue)

简介 Vue是前端优秀框架是一套用于构建用户界面的渐进式框架 Vue优点 Vue是目前前端最火的框架之一 Vue是目前企业技术栈中要求的知识点 vue可以提升开发体验 Vue学习难度较低 Vue开发前准备 一、nodejs环境 Nodejs简介 Nodejs诞生于2009年&#xff0c;主攻服务器方向&#x…

Github Coplit的认证及其在JetBrains中的使用

原文地址&#xff1a;Github Coplit的认证及其在JetBrains中的使用 - Pleasure的博客 下面是正文内容&#xff1a; 前言 今天分享一个可有可无的小技巧&#xff0c;水一篇文。 如标题所述&#xff0c;Github Coplit的认证及其在JetBrains中的使用 正文 介绍JetBrains JetBrain…

BCD BIN 转换

1&#xff0c;BCD是将10进制的每一位转换成2进制 如22 的中数子2的2进制就是0010&#xff0c;那么22的BCD 嘛就是 0010 0010 2&#xff0c;bin 的就是将2进制的每4位转成10进制 如 34的2进制就是0010 0010 高四位和低四位都是 0010 &#xff0c;0010对应的10进制就是2 那么…

ELFK日志分析系统之搭建ELF+Filebeaat+Zookeeper+Kafka

引言 结合前面所学 http://ELK日志分析系统 一、为什么要做日志分析平台 随着业务量的增长&#xff0c;每天业务服务器将会产生上亿条的日志&#xff0c;单个日志文件达几个GB&#xff0c;这时我们发现用Linux自带工具&#xff0c;cat grep awk 分析越来越力不从心了&#…

(四)qt中使用ffmpeg播放视频,可暂停恢复

一、在qt中添加ffmpeg库及头文件 INCLUDEPATH /usr/local/ffmpeg/include LIBS -L/usr/local/lib -lavutil -lavcodec -lavformat -lswscale 二、详细代码 FFempegVideoDecode 视频解码类&#xff08;放入线程中&#xff09; ffmpegvideodecode.h #ifndef FFMPEGVIDEODE…

程序猿没有副业,太难了

副业的初衷 我知道踏下心来钻研本专业会有收获,但又实在没有太多兴趣。 只好努努力,跟着兴致走,多一个选择,多一份抵抗风险的能力。 不管从事什么行业&#xff0c;除了做好自己本职工作以外&#xff0c;还会有一些空闲的时间来做一些其他事情&#xff0c;与其说是副业,不如说…

JavaScript教程(十四)--- 类型化数组

JavaScript 类型化数组 JavaScript 类型化数组是一种类似数组的对象&#xff0c;并提供了一种用于在内存缓冲中访问原始二进制数据的机制。 引入类型化数组并非是为了取代 JavaScript 中数组的任何一种功能。相反&#xff0c;它为开发者提供了一个操作二进制数据的接口。这在操…

OSCP靶场--PayDay

OSCP靶场–PayDay 考点(公共exp文件上传密码复用sudo -l all提权) 1.nmap扫描 ## ┌──(root㉿kali)-[~/Desktop] └─# nmap -sV -sC 192.168.153.39 -p- -Pn --min-rate 2500 Starting Nmap 7.92 ( https://nmap.org ) at 2024-04-13 04:52 EDT Nmap scan report for 192…

常见的锁策略,synchronized优化过程和cas过程

1. 常见的锁策略 所谓"策略",也可以理解为做法."锁策略"就是用来描述一把锁面对加锁/解锁时的做法. 1.1 乐观锁 vs 悲观锁 要区分一把锁是乐观锁还是悲观锁,就要预测当前这把锁冲突的概率高不高. 如果冲突概率高,后续要做的工作往往会更多,加锁的开销就…

python画神经网络图

代码1(画神经网络连接图&#xff09; from math import cos, sin, atan import matplotlib.pyplot as plt # 注意这里并没有用到这个networkx这个库&#xff0c;完全是根据matploblib这个库来画的。 class Neuron():def __init__(self, x, y,radius,nameNone):self.x xself.y …

Qt学习记录(C++)——Day 3

目录 一、封装自定义控件 1.添加界面类 2.添加控件 3.提升封装的控件 4.实现功能 5.提供接口 6.测试接口 二、鼠标事件 前言&#xff1a; 1.鼠标进入事件 enterEvent 2.鼠标离开事件 leaveEvent 3.鼠标按下事件 mousePressEvent 4.鼠标释放事件 mouseReleaseEv…

表格头部合并,数据和表头中间插入合计和样式合并

在做项目时其中一个页面要求和Excel格式一样的页面 html数据&#xff0c;大概写了几个案例如下 <el-table v-loading"loading" :data"tableList" :span-method"mergeRow">//:span-method"mergeRow" 用于合并第一行<el-table…

传统图机器学习的特征工程-全图

将整张图表示成为一个低维向量&#xff0c;反映全图的特征 key idea&#xff1a;Bag-of-Words&#xff08;BOW&#xff09;把图看作文章&#xff0c;把节点看作单词 Kernel mothods

基于SSM+Jsp+Mysql的网络视频播放器

开发语言&#xff1a;Java框架&#xff1a;ssm技术&#xff1a;JSPJDK版本&#xff1a;JDK1.8服务器&#xff1a;tomcat7数据库&#xff1a;mysql 5.7&#xff08;一定要5.7版本&#xff09;数据库工具&#xff1a;Navicat11开发软件&#xff1a;eclipse/myeclipse/ideaMaven包…