PLM之家PLMHome-国产软件践行者

[转载电子书] C++中的string查找使用详解

[复制链接]

2014-3-9 12:47:32 4418 0

mildcat 发表于 2014-3-9 12:47:32 |阅读模式

mildcat 楼主

2014-3-9 12:47:32

请使用QQ关联注册PLM之家,学习更多关于内容,更多精彩原创视频供你学习!

您需要 登录 才可以下载或查看,没有账号?注册

x
由于查找是使用最为频繁的功能之一,string 提供了非常丰富的查找函数。其列表如下:
) N: p1 C+ ?! _0 A: I4 w0 Y
函数名
描述
find查找
rfind反向查找
find_first_of查找包含子串中的任何字符,返回第一个位置
find_first_not_of查找不包含子串中的任何字符,返回第一个位置
find_last_of查找包含子串中的任何字符,返回最后一个位置
find_last_not_of查找不包含子串中的任何字符,返回最后一个位置

2 v8 o  ~2 e" h/ [8 ^以上函数都是被重载了4次,以下是以find_first_of 函数为例说明他们的参数,其他函数和其参数一样,也就是说总共有24个函数。
! n) E; a/ t7 f6 L6 V% s
+ W7 F9 v! x6 R
) r9 z, U+ J( h  y( Z
  • size_type find_first_of(const basic_string& s, size_type pos = 0)  
  • size_type find_first_of(const charT* s, size_type pos, size_type n)  
  • size_type find_first_of(const charT* s, size_type pos = 0)  
  • size_type find_first_of(charT c, size_type pos = 0)  
    5 ?( f* [4 h4 P5 x
* ?5 o8 z* H. Q7 X. i+ i# x
size_type find_first_of(const basic_string& s, size_type pos = 0)size_type find_first_of(const charT* s, size_type pos, size_type n)size_type find_first_of(const charT* s, size_type pos = 0)size_type find_first_of(charT c, size_type pos = 0)
: T8 u5 T/ q/ Q" c5 X1 l0 M( Q2 n- C9 Z! o3 ~9 L/ z
所有的查找函数都返回一个size_type类型,这个返回值一般都是所找到字符串的位置,如果没有找到,则返回string::npos。有一点需要特别注意,所有和string::npos的比较一定要用string::size_type来使用,不要直接使用int 或者unsigned int等类型。其实string::npos表示的是-1, 看看头文件:
8 U6 Y  a$ ^1 S+ a1 m5 j
  i: C  e% R, o9 i- G
9 Y- ?7 b4 S5 _& j
  • template <class _CharT, class _Traits, class _Alloc>   
  • const basic_string<_CharT,_Traits,_Alloc>::size_type   
  • basic_string<_CharT,_Traits,_Alloc>::npos   
  • = basic_string<_CharT,_Traits,_Alloc>::size_type) -1;  ( q6 w1 |) p& M- Y
2 r% v3 ^- u; d! V/ C* m
template <class _CharT, class _Traits, class _Alloc> const basic_string<_CharT,_Traits,_Alloc>::size_type basic_string<_CharT,_Traits,_Alloc>::npos = basic_string<_CharT,_Traits,_Alloc>::size_type) -1;
* S! e/ y; Z& G" w/ r# u* S5 b/ \
find 和 rfind 都还比较容易理解,一个是正向匹配,一个是逆向匹配,后面的参数pos都是用来指定起始查找位置。对于find_first_of 和find_last_of 就不是那么好理解。
find_first_of 是给定一个要查找的字符集,找到这个字符集中任何一个字符所在字符串中第一个位置。或许看一个例子更容易明白。
有这样一个需求:过滤一行开头和结尾的所有非英文字符。看看用string 如何实现:

1 b' R* `8 T6 @  f$ a
6 x. a# J1 I# l0 B2 b
  • #include <string>  
  • #include <iostream>  
  • using namespace std;  
  • int main(){  
  •         string strinfo="   //*---Hello Word!......------";  
  •         string strset="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz";  
  •         int first = strinfo.find_first_of(strset);  
  •         if(first == string::npos) {   
  •                 cout<<"not find any characters"<<endl;  
  •                 return -1;  
  •         }   
  •         int last = strinfo.find_last_of(strset);  
  •         if(last == string::npos) {   
  •                 cout<<"not find any characters"<<endl;  
  •                 return -1;  
  •         }   
  •         cout << strinfo.substr(first, last - first + 1)<<endl;  
  •         return 0;  
  • }  
    $ a8 U/ K, J; s3 j3 k3 o  K5 o1 Y0 J
) w" ~* a9 x( p6 R
#include <string>#include <iostream>using namespace std;int main(){        string strinfo="   //*---Hello Word!......------";        string strset="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz";        int first = strinfo.find_first_of(strset);        if(first == string::npos) {                 cout<<"not find any characters"<<endl;                return -1;        }         int last = strinfo.find_last_of(strset);        if(last == string::npos) {                 cout<<"not find any characters"<<endl;                return -1;        }         cout << strinfo.substr(first, last - first + 1)<<endl;        return 0;}, d2 T  a- m9 M) \% Y. E5 W
' N6 J% g( b: E% Y, _) D( [
- [- c3 u/ r, ?4 A2 `
- E4 I4 b" F% M' Y" j  x3 o
该会员没有填写今日想说内容.
回复

使用道具 举报

发表回复

您需要登录后才可以回帖 登录 | 注册

返回列表 本版积分规则

  • 发布新帖

  • 在线客服

  • 微信

  • 客户端

  • 返回顶部

  • x
    温馨提示

    本网站(plmhome.com)为PLM之家工业软件学习官网站

    展示的视频材料全部免费,需要高清和特殊技术支持请联系 QQ: 939801026

    PLM之家NX CAM二次开发专题模块培训报名开始啦

    我知道了