strstr
char * strstr ( const char * ,const char * ) ;
在一个字符串中找另外一个字符串,找到了返回符合的子串的首地址,找不到就返回NULL
strstr函数实现
char* my_strstr(const char* str1, const char* str2)
{
const char* p1 = NULL;
const char* p2 = NULL;
const char* temp = str1; /*再加多一个指针保存str1开始比较的字符位置,如果从第一个字符开始比较,到后面某个字符不匹 配时,temp+1,开始第二个字符依次比较*/
while (*temp)
{
p1 = temp;
p2 = str2;
while (*p1 && *p2 && (*p1 == *p2)) //只有当p1和p2没有找到'\0'时,当两个字符相等,再向后比较
{
p1++;
p2++;
}
//当有字符不相等时,判断p2是否已经到'\0'了而此时p1可能还有字符,到'\0'则说明str2比较完了,没有则继续
if (*p2 == '\0')
{
return (char*)temp;
}
temp++;
}
return NULL;
}
strtok
切割字符串
char * strtk ( char * str,const char * sep );
1.sep参数是个字符串,定义了用作分隔符的字符集合
2.第一个参数指定一个字符串,它包含了0个或者多个由sep字符串中一个或者多个分隔符分割的标记。
3.strtok函数找到str中的下一个标记,并将其用\0结尾,返回一个指向这个标记的指针。(注:strtok函数会改变被操作的字符串,所以在使用strtok函数切分的字符串一般都是临时拷贝的内容并且可修改。)(按什么字符切割,就在字符串中把该字符换成’\0’)
4.strtok函数的第一个参数不为NULL,函数将找到str中第一个标记,strtok函数将保存它在字符串中的位置。
5.strtok函数的第一个参数为NULL,函数将在同一个字符串中被保存的位置开始,查找下一个标记。(结合第4点,strtok函数第一次传字符串过去,之后传NULL过去,每次传NULL值都会在上一次使用时保存的标记处开始)
6.如果字符串中不存在更多的标记,则返回NULL指针。
char arr[] = " abc@12581.qq" ;
char* p = "@. " ;
char* temp[20] = {0};
strcpy(temp,arr);
for (ret = strtok(temp,p); ret != NULL; ret=strtok (NULL,p))
{
...
}
第一次调用时传入字符串temp,会找到@的位置,并将其置为’\0’,保存该’\0’的位置,返回abc的指针,第二次后传入NULL值,并从上次的’\0’处继续往后找,找到.后改为’\0’,保存位置,并返回12581的指针
如果多条语句全写成strtok(arr,p);不传入空值的话,每次打印都是开头到一个分隔符之间的子串,就全是abc