【FROM MSDN && 百科】
原型:char *strstr(const char *str1, const char *str2);
#include<string.h>
找出str2字符串在str1字符串中第一次出现的位置(不包括str2的串结束符)。返回该位置的指针,如找不到,返回空指针。
Returns a pointer to the first occurrence of strSearch in str, or NULL if strSearch does not appear in str. If strSearch points to a string of zero length, the function returns str.
DEMO: mystrstr
#include <stdio.h> #include <conio.h> #include <string.h> #include <stdlib.h> #pragma warning (disable:4996) char *mystrstr(char *s1,char *s2); int main(void) { char *s="Golden Global View"; char *l="ob"; //char *l="" char *p; system("cls"); p=mystrstr(s,l); if (p!=NULL) { printf("%s\n",p); } else { printf("Not Found!\n"); } getch(); return 0; } /*FROM 百科*/ char *mystrstr(char *s1,char *s2) { int n; if (*s2) //两种情况考虑 { while(*s1) { for (n=0;*(s1+n)==*(s2+n);n++) { if (!*(s2+n+1)) //查找的下一个字符是否为'\0' { return (char*)s1; } } s1++; } return NULL; } else { return (char*)s1; } }
DEMO:
//#define FIRST_DEMO #define SECOND_DEMO #ifdef FIRST_DEMO #include <stdio.h> #include <conio.h> #include <string.h> int main(void) { char *s="Golden Global View"; char *l="lob"; char *p; system("cls"); p=strstr(s,l); if (p!=NULL) { printf("%s\n",p); } else { printf("Not Found!\n"); } getch(); return 0; } #elif defined SECOND_DEMO /*从字串” string1 onexxx string2 oneyyy”中寻找”yyy”*/ #include <stdio.h> #include <conio.h> #include <string.h> int main(void) { char *s="string1 onexxx string2 oneyyy"; char *p; p=strstr(s,"string2"); printf("%s\n",p); if (p==NULL) { printf("Not Found!\n"); } p=strstr(p,"one"); printf("%s\n",p); if (p==NULL) { printf("Not Found!\n"); } p+=strlen("one"); printf("%s\n",p); getch(); return 0; } #endif
今天的文章 C语言之strstr函数分享到此就结束了,感谢您的阅读。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/bian-cheng-ji-chu/77867.html