Strstr和Strchr函数详解

Strstr函数详解

Strstr函数原型

char *strstr( const char *string, const char *strCharSet );

Strstr函数功能

  • 在一个字符串中找另一个字符串(查找字符串)
  • strstr(str1,str2) 函数用于判断字符串str2是否是str1的子串。如果是,则该函数返回 str1字符串从 str2第一次出现的位置开始到 str1结尾的字符串;否则,返回NULL。
  • 返回值是指针,返回的是子字符串在原先字符串中第一次出现的位置,如果没有找到的话,就返回NULL

库函数下的strstr

#include
#include
int main()
{
	char arr1[] = "abcdef";
	char arr2[] = "bcd";
	char *ret = strstr(arr1, arr2);
	if (ret == NULL)
	{
		printf("不存在\n");
	}
	else
	{
		printf("%s\n", ret);
	}
	return 0;
}

模拟实现strstr

/*
当*start!='\0'的时候,就把start赋值给s1,让他去查找,把str2赋值给s2
让s2也从起始位置开始,然后循环的判断条件 *s1 != '\0' && *s2 != '\0' && *s1 == *s2
然后s1和s2进行加加,加加完了之后,再上去判断,当有一次,s1或者s2
等于'\0’的时候,或者他们不相等的时候,就跳出来,如果*str2=='\0'的时候,就是找到了,然后跳出来
如果找不到的话,就返回空指针。
如果要找一个空字符串的话(特殊情况):
在库里面,对于这种特殊情况的处理,就是直接返回str1
*/
#include
#include
char* my_strstr(const char* str1, const char* str2)
{
	const char* s1 = str1;
	const char* s2 = str2;
	const char* start = str1;
	assert(str1 != NULL);
	assert(str2 != NULL);
	if (*str2 == '\0')
	{
		return (char *)str1;   //找空字符串,直接返回str1
	}
	while (*start!='\0')//当start遇到'\0'的时候就没有比要再继续查找了,那一定是查找不到的了
	{
		s2 = str2;
		s1 = start;
		while (*s1 != '\0' && *s2 != '\0' && *s1 == *s2)
		{
			s1++;
			s2++;
		}
		if (*s2 == '\0')
		{
			return (char *)start;
		}
		start++;
	}
	return NULL;
}
int main()
{
	char arr1[] = "abcdefabcdef";
	char arr2[] = "bcd";
	char* ret = my_strstr(arr1, arr2);
	if (*ret == NULL)
	{
		printf("不存在\n");
	}
	else
	{
		printf("%s\n", ret);
	}
	return 0;
}

Strchr

Strchr函数原型

char *strchr( const char *string, int c );

Strchr函数功能

  • strchr函数功能为在一个串中查找给定字符的第一个匹配之处。函数原型为:char *strchr(const char *str, int c),即在参数 str 所指向的字符串中搜索第一次出现字符 c(一个无符号字符)的位置。strchr函数包含在C 标准库 中。
  • str-- 要被检索的 C 字符串。
  • c-- 在 str 中要搜索的字符。
  • 返回一个指向该字符串中第一次出现的字符的指针,如果字符串中不包含该字符则返回NULL空指针。
  • 注意,该函数式大小写区分的函数,大小字母和小写字母被看成是不一样的

使用实例子

#include 
#include 
int main ()
{
   const char str[] = "http://www.runoob.com";
   const char ch = '.';
   char *ret;
   ret = strchr(str, ch);
   printf("|%c| 之后的字符串是 - |%s|\n", ch, ret);
   return(0);
}

Strchr的模拟实现

#include
#include
char* my_strchr(const char* str, const char ch)
{
	assert(str);
	const char* dest = str;
	while (dest != '\0' && *dest != ch)
	{
		dest++;
	}
	if (*dest == ch)
		return (char*)dest;
	return NULL;
}
int main()
{
	char* ret = my_strchr("hello", 'l');
	if (ret == NULL)
		printf("不存在");
	else
		printf("%s\n", ret);
	return 0;
}

你可能感兴趣的:(C/C++)