1 ////find函数返回类型 size_type 2 string s("1a2b3c4d5e6f7g8h9i1a2b3c4d5e6f7g8ha9i"); 3 string flag; 4 string::size_type position; 5 6 //find 函数 返回jk 在s 中的下标位置 7 position = s.find("jk"); 8 if (position != s.npos) //如果没找到,返回一个特别的标志c++中用npos表示,我这里npos取值是4294967295, 9 { 10 cout << "position is : " << position << endl; 11 } 12 else 13 { 14 cout << "Not found the flag" + flag; 15 } 16 17 18 //find 函数 返回flag 中任意字符 在s 中第一次出现的下标位置 19 flag = "c"; 20 position = s.find_first_of(flag); 21 cout << "s.find_first_of(flag) is : " << position << endl; 22 23 //从字符串s 下标5开始,查找字符串b ,返回b 在s 中的下标 24 position=s.find("b",5); 25 cout<<"s.find(b,5) is : "<<position<<endl; 26 27 //查找s 中flag 出现的所有位置。 28 flag="a"; 29 position=0; 30 int i=1; 31 while((position=s.find_first_of(flag,position))!=string::npos) 32 { 33 //position=s.find_first_of(flag,position); 34 cout<<"position "<<i<<" : "<<position<<endl; 35 position++; 36 i++; 37 } 38 39 //查找flag 中与s 第一个不匹配的位置 40 flag="acb12389efgxyz789"; 41 position=flag.find_first_not_of (s); 42 cout<<"flag.find_first_not_of (s) :"<<position<<endl; 43 44 45 //反向查找,flag 在s 中最后出现的位置 46 flag="3"; 47 position=s.rfind (flag); 48 cout<<"s.rfind (flag) :"<<position<<endl; 49 }
在写C++程序中,总会遇到要从一个字符串中查找一小段子字符串的情况,对于在C中,我们经常用到strstr()或者strchr()这两种方法。而对于C++的string,我们往往会用到find()。
C++:#inlcude C: #include<string.h>
find():在一个字符串中查找一个指定的单个字符或字符数组。如果找到,就返回首次匹配的开始位置;如果没有查找到匹配的内容,就返回string::npos。
find_first_of():在一个目标串中进行查找,返回值是第一个与指定字符组中任何字符匹配的字符位置。如果没有查找到匹配的内容,则返回npos。
find_last_of():在一个目标串中进行查找,返回最后一个与指定字符组中任何字符匹配的字符位置。如果没有查找到匹配的内容,则返回npos
find_first_not_of():在一个目标串中进行查找,返回第一个与指定字符组中任何字符都不匹配的元素位置。如果找不到那样的元素则返回npos
find_last_not_of():在一个目标串中进行查找,返回下标值最大的与指定字符组中任何字符都不匹配的元素的位置。若找不到那样的元素则返回npos。
rfind():对一个串从尾至头查找一个指定的单个字符或字符组。如果找到,就返回首次匹配的开始位置;如果没有查找到匹配的内容,则返回npos。
find(string, int):第一个参数用来指示要查找的字符,第二个参数用来表示从字符串的何处开始查找子串(默认的查找位置是0)。