【C语言】strncat、strncmp、strstr函数讲解

本篇博客将讲解函数:strncat、strncmp、strstr函数

注意:使用strncat、strncmp、strstr函数时要包含头文件:string.h

1、strncat函数的使用(是从目标空间中第一个的'\0'位置开始追加的)

strncat函数原型:

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

(1)将source指向的字符串的前num个字符追加到destination 指向的字符串末尾,再加一个'\0'字符。

(2)如果source指向的字符串的长度小于num,只会将source指向的字符串到'\0'(包含'\0')的内容追加到destination指向的字符串。

代码示例:

2、strncmp函数的使用

strncmp函数原型:

int strncmp(const char* str1, const char* str2,size_t num);

比较str1和str2的前num个字符,如果相等就继续往后比较,最多比较num个字符,如果比较第n(n<=m)个字符不一样时,就提前结束,大的字符所在字符串大于另外一个。如果num个字符都相等,则这两个字符串相等。

代码示例:

3、strstr的使用和模拟实现

(1)strstr的使用(strstr是在一个字符串中查找另外一个字符串)

strstr函数原型:

char* strstr(const char* str,1 const char* str2);

1))函数返回字符串str2在字符串str1中第一次出现的位置。如果str2不再str1中,返回空指针(NULL);

2))字符串的比较匹配不包含'\0'字符,以'\0'作为结束符号

代码示例:

(2)strstr函数的模拟实现

1))复杂的情况

2))最简单的情况

3))找不到的情况

代码:

#define _CRT_SECURE_NO_WARNINGS

#include<stdio.h>

#include<string.h>

char* my_strstr(const char* str1, const char* str2)

{

const char* s1 = NULL;

const char* s2 = NULL;

const char* cur = str1;

if (*str2 == '\0')//str2是空字符串的情况

{

return (char*)str1;

//注意:const char* 与char *类型不同,所以要强制类型转换

}

while (*cur)

{

s1 = cur;

s2 = str2;

while (*s1 != '\0' && *s2 != '\0' && *s1 == *s2)

{

s1++;

s2++;

}

if (*s2 == '\0')

{

return (char*)cur;

}

cur++;

}

return NULL;

}

int main()

{

char arr1[] = "abcdefabcdef";

char arr2[] = "cdef";

char* ret = my_strstr(arr1, arr2);

if (ret == NULL)

{

printf("找不到\n");

}

else

{

printf("%s\n", ret);

}

return 0;

}

相关推荐
小王不爱笑1323 小时前
IO 模型
开发语言·python
知我Deja_Vu3 小时前
【避坑指南】ConcurrentHashMap 并发计数优化实战
java·开发语言·python
AI+程序员在路上4 小时前
CANopen 协议:介绍、调试命令与应用
linux·c语言·开发语言·网络
2401_831824964 小时前
基于C++的区块链实现
开发语言·c++·算法
爱编码的小八嘎4 小时前
C语言完美演绎4-4
c语言
m0_518019484 小时前
C++与机器学习框架
开发语言·c++·算法
ZTLJQ4 小时前
深入理解逻辑回归:从数学原理到实战应用
开发语言·python·机器学习
qq_417695054 小时前
C++中的代理模式高级应用
开发语言·c++·算法
波波0075 小时前
每日一题:.NET 中的“反射”是什么?
开发语言·.net
Book思议-5 小时前
【数据结构实战】线性表的应用
c语言·数据结构·算法·链表