作者:旧梦拾遗

专栏:C语言编程----小比特成长日记

每日励志:

不想认命,就去拼命,我始终相信,付出就会有收获,或大或小,或迟或早,始终不会辜负你的努力。有一种落差是,你总是羡慕别人的成功,自己却不敢开始。

前言:

上篇我们学到了,不受长度受限制的字符串函数----strncpy,strncat,strncmp,今天小编讲一些其它类型的函数---strstr,strtok,strerror函数和字符分类函数字符转换函数。

目录

目录

一.strstr函数子字符串查找函数:

1.功能:

2.函数自身的实现方法:

a)源字符串能够在目标字符串中一次匹配就能找到

b)源字符串多次匹配才能成功

3.函数的模拟实现:

思路:

​编辑

代码:

结果:

二.strtok切割字符串函数:

1.功能:

2. 代码:

3.结果:

4.模拟strtok:

a)代码:

b)结果:

三.strerror错误报告函数:

1.功能:

2.代码:

a)

b)

四.字符分类函数:

五.字符转换函数:

六:自负转换函数与自负分类函数综合案例

1.代码:

2. 结果:


一.strstr函数子字符串查找函数:

1.功能:

2.函数自身的实现方法:

这里可以大致分为两种情况讨论

a)源字符串能够在目标字符串中一次匹配就能找到

大致思路是假设指针s1指向目标字符串首地址,指针s2指向源字符串首地址,分别对指针s1和s2解引用并比较,若匹配内容不相同我们称之为匹配失败,则目标字符串指针s1,向后移动一位,若匹配内容相同我们称之为第n次匹配,则指针s1和s2,分别后移,直到目标指针s2指向字符'\0',结束例如。

注意:(若s2指针指向字符串首地址的内容和s1指向的字符串地址的内容相同,我们称之为第

n次匹配)

#include<stdio.h>
#include<string.h>
int main()
{char arr1[] = "cbbac";char* ch=strstr(arr1, "bba");printf("%s", ch);return 0;}

最后函数返回第一次就能匹配成功的首地址。

结果:

b)源字符串多次匹配才能成功

大致思路是假设指针s1指向目标字符串首地址,指针s2指向目标字符串首地址,分别对指针s1和s2解引用并比较,若匹配内容不相同我们称之为匹配失败,则目标字符串指针s1,向后移动一位,若匹配内容相同我们称之为第n次匹配,假设第一次匹配成功则我们将第一次匹配中的指针s1和s2分别后移,若后移后指针s1和s2指向的内容不相同,则第一次匹配失败,s1回到第一次匹配的首位值得下一位,s2回到首地址,若此时指针s1和s2指向的内容相同则,开启第二次匹配,以此类推直到s2指向空,则匹配成功。

例如:

#include<stdio.h>
#include<string.h>
int main()
{char arr1[] = "aabba";char* ch=strstr(arr1, "abb");printf("%s", ch);return 0;}

结果:

3.函数的模拟实现:

思路:

1.源字符串能够在目标字符串中一次匹配就能找到

大致思路是假设指针s1指向原字符串首地址,指针s2指向目标字符串首地址,分别对指针s1和s2解引用并比较,若匹配内容不相同我们称之为匹配失败,则原字符串指针s1,向后移动一位,若匹配内容相同我们称之为第n次匹配,假设第一次匹配成功则我们将第一次匹配中的指针s1和s2分别后移,若后移后指针s1和s2指向的内容不相同,则第一次匹配失败,s1回到第一次匹配的首位值得下一位,s2回到首地址,若此时指针s1和s2指向的内容相同则,开启第二次匹配,以此类推直到s2指向空,则匹配成功。

2.源字符串多次匹配才能成功

大致思路是假设指针s1指向目标字符串首地址,指针s2指向源字符串首地址,分别对指针s1和s2解引用并比较,若匹配内容不相同我们称之为匹配失败,则目标字符串指针s1,向后移动一位,若匹配内容相同我们称之为第n次匹配,假设第一次匹配成功则我们将第一次匹配中的指针s1和s2分别后移,若后移后指针s1和s2指向的内容不相同,则第一次匹配失败,s1回到第一次匹配的首位值得下一位,s2回到首地址,若此时指针s1和s2指向的内容相同则,开启第二次匹配,以此类推直到s2指向空,则匹配成功。

3.这里我们以指针p来记录第n此匹配的起始位置;

代码:

 #include<stdio.h>
#include<assert.h>
char* my_strstr(const char* arr1,const char* arr2)
{assert(arr1 && arr2);const char* s1 = arr1;const char* s2 = arr2;const char* p = arr1;while (*p){s1 = p;s2 = arr2;while (*s1 != '\0' && *s2 != '\0' && *s1 == *s2){s1++;s2++;}if (*s2 == '\0'){return (char*)p;}p++;}return NULL;
}
int main()
{char arr1[] = "aabba";char arr2[] = "abb";char* ch = my_strstr(arr1, arr2);if (ch == NULL){printf("子字符串不存在\n");}printf("%s", ch);return 0;
}

结果:

二.strtok切割字符串函数:

1.功能:

在这里解释一下:

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

2. 代码:

#include<stdio.h>
#include<string.h>int main()
{const char* sep = "@.";char email[] = "zhangpengwei@bitejiuyeke.com.net";char cp[40] = { 0 };//"zhangpengwei@bitejiuyeke.com"strcpy(cp, email);char* ret = strtok(cp, sep);if(ret != NULL)printf("%s\n", ret);ret = strtok(NULL, sep);if (ret != NULL)printf("%s\n", ret);ret = strtok(NULL, sep);if (ret != NULL)printf("%s\n", ret);ret = strtok(NULL, sep);if (ret != NULL)printf("%s\n", ret);return 0;
}

以为这就完了?

事实上代码可以进行简化:

#include<stdio.h>
#include<string.h>int main()
{const char* sep = "@.";char email[] = "zhangpengwei@bitejiuyeke.com.net";char cp[40] = { 0 };//"zhangpengwei@bitejiuyeke.com"strcpy(cp, email);char* ret = NULL;for (ret = strtok(cp, sep); ret != NULL; ret=strtok(NULL, sep)){printf("%s\n", ret);}return 0;
}

3.结果:

4.模拟strtok:

a)代码:


#include<stdio.h>
#include<assert.h>
#include<string.h>
//模拟实现strtok  字符串切割函数
char* my_strtok(char* str1, const char* str2)
{assert(str2);static int sz1 = NULL;static int count = NULL;static char* s1 = NULL;static char* s2 = NULL;int sz = 0;if (str1 != NULL)//说明是第一次进入。{sz1 = strlen(str1);//计算出str1中所有字符的个数s2 = str1;//记录初始地址,等下找到分割符时,将这个地址返回。sz = strlen(str2);for (*str1; *str1 != 0; str1++){          for (int i = 0; i < sz; i++){  if (i == 0){count++;}if (*str1 == *(str2 + i)){*str1 = 0;s1 = str1;//记录这一次置0的位置。return s2;}            }}}else{s2 = s1+1;   str1 = s2;sz = strlen(str2);for (*str1; *str1 != 0; str1++){           for (int i = 0; i < sz; i++){ if (i == 0){count++;}if (*str1 == *(str2 + i)){*str1 = 0;s1 = str1;//记录这一次置0的位置。return s2;}    }}if (count > sz1){return NULL;}return s2;}}
int main()
{char arr[20] = "12@34.5";char* p = "@.";char* str = NULL;for (str = my_strtok(arr, p); str != NULL; str = my_strtok(NULL, p)){printf("%s\n", str);}return 0;
}

b)结果:

这里需要注意的就是当目的字符串被遍历完成之后,再次调用该函数会返回一个NULL指针。我是以计数器的方式进行实现,每当成功比对一个字符,就进行一次计数,当计数的个数比目的字符串字符个数大时,说明目的字符串被遍历完成了,此时会返回空指针。

三.strerror错误报告函数:

1.功能:

返回错误码,所对应的错误信息。

2.代码:

a)

注意:

C语言的库函数,在执行失败的时候,都会设置错误码
0 1 2 3 4 5 6 7 8
#include<stdio.h>
#include<string.h>
int main()
{printf("%s\n", strerror(0));printf("%s\n", strerror(1));printf("%s\n", strerror(2));printf("%s\n", strerror(3));printf("%s\n", strerror(4));printf("%s\n", strerror(5));return 0;
}

结果:

b)

errno - C语言设置的一个全局的错误码存放的变量

#include<stdio.h>
#include<string.h>
#include<errno.h>
int main()
{FILE* pf = fopen("C:\\Users\\zpeng\\Desktop\\test.txt", "r");if (pf == NULL){printf("%s\n", strerror(errno));return 1;}else{//}return 0;
}

如果文件夹不在会返回错误信息进行提醒:

四.字符分类函数:

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

五.字符转换函数:

int tolower ( int c )
int toupper  ( int c )

六:自负转换函数与自负分类函数综合案例

1.代码:

#include<stdio.h>
#include <stdio.h>
#include <ctype.h>
int main()
{int i = 0;char str[] = "Test String.\n";char c;while (str[i]){c = str[i];if (isupper(c))c = tolower(c);putchar(c);i++;}return 0;
}

2. 结果:

结语:

每个人的成长都是能力和想要得到的东西,不断匹配的过程,当你的才华和欲望不匹配时,你就该静下心来学习了,如果小编的总结能对你有所帮助,希望小伙伴们三连加关注哦,你的支持是小编创作的最大动力。

字符串函数---其他类型的函数(strstr,strtok,strerror函数和字符分类函数字符转换函数)努力积累才能进大厂拿offer相关推荐

  1. 字符串函数中的求长度、查找、分割和错误报告函数(strlen,strstr,strtok,strerror)

    文章目录 一.strlen - 求字符串长度 1.函数介绍 2.模拟实现(三种方式) 二.strstr - 字符串查找 1.函数介绍 2.模拟实现 三.strtok - 字符串分割 四.strerro ...

  2. 【C】字符串库函数及重点函数的模拟实现(下)—— strstr | strtok | strerror

    本文重点 8.strstr 9.strtok 10.strerror 本文将继续介绍字符串库函数,即重点函数的模拟实现. 8.strstr

  3. strlen strstr strtok strerror 函数解析及模拟实现

    文章目录 一.strlen 求字符串长度 1.函数介绍 2.模拟实现(三种方式) 二.strstr 字符串查找 1.函数介绍 2.模拟实现 三.strtok 字符串分割 四.strerror perr ...

  4. 【转】python中的字符数字之间的转换函数

    int(x [,base ])         将x转换为一个整数     long(x [,base ])        将x转换为一个长整数     float(x )               ...

  5. python中的字符数字之间的转换函数

    转自http://www.cnblogs.com/wuxiangli/p/6046800.html int(x [,base ])         将x转换为一个整数 long(x [,base ]) ...

  6. JS 中字符和 ASCII码转换函数

    字符转ascii码:用charCodeAt(); ascii码砖字符:用fromCharCode(); 看一个小例子 <script> str="A"; code = ...

  7. C++指针详解2_typedef函数声明类型、sizeof特性简介与数组指针间关系说明

    本节主要内容 typedef函数声明 函数指针变量声明类型 函数指针与函数指针数组 sizeof 数组与指针的关系 函数形参接收数组与接收指针的关系 基本函数声明类型与使用 使用typedef进行函数 ...

  8. 函数指针和函数指针类型

    参考:https://blog.csdn.net/candyliuxj/article/details/6339414 函数指针 1.     定义 每一个函数都占用一段内存单元,它们有一个起始地址, ...

  9. SQL转换函数to_char/to_date/to_number

    日期型->字符型转换函数to_char(d [,fmt]) 函数to_char(d [,fmt])用于将日期型数值转换为字符串(varchar2类型),其中参数d用于指定日期值,fmt用于指定要 ...

最新文章

  1. CentOS需要安装的JAVA环境的相关软件
  2. 10个解放双手实用在线工具,有些代码真的不用手写
  3. webpack结合reactjs、vuejs项目中图片处理
  4. Python语言学习之字母D开头函数使用集锦:del、dict使用方法之详细攻略
  5. Android之Handler用法总结(1)
  6. java java.doc_使用 javadoc 自动生成 Java 文档
  7. 3-30Pytorch与auto-variabletensor
  8. 菜鸟学习笔记:Java提升篇5(IO流1——IO流的概念、字节流、字符流、缓冲流、转换流)
  9. Python回归 岭回归(Ridge Regression)
  10. BZOJ.4650.[NOI2016]优秀的拆分(后缀数组 思路)
  11. 【转】android新建项目时 出现appcompat_v7工程错误和红色感叹号
  12. 使用REG注册表文件添加、修改或删除注册表键值和子项介绍
  13. Knockout+RequireJS+Sammy搭建简单的SPA脚手架
  14. 静态IP和动态IP有什么区别?
  15. 基于GPT模型的对话系统
  16. java39阶台阶_第四届蓝桥杯javaC组_第39级台阶
  17. [iOS] Xcode 5 + iOS 7免证书(iDP)真机调试与生成IPA全攻略
  18. 整人用的强制关机小程序
  19. 详解清除MongoDB所占用的多余的磁盘空间的方法
  20. 小李的电商日记 22.10.12

热门文章

  1. Python_Selenium使用
  2. EXCLE 使用MID函数实现快速填充年月日
  3. 隐函数+导数定义思路
  4. 股票投资股市入门理论知识入门须知<第二天>
  5. 我们无法驱散雾霾,但能教会你正确选戴口罩!
  6. 【书籍】Writing Science How to Write Papers That Get Cited and Proposals That Get Funded阅读小结
  7. 车辆转向不足转向过度个人总结
  8. bugfree安装问题
  9. Robot Framework-DatabaseLibrary(MySql)
  10. SPU与SKU的简单理解