PLM之家PLMHome-工业软件践行者

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

[复制链接]

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

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

mildcat 楼主

2014-3-9 12:47:32

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

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

x
由于查找是使用最为频繁的功能之一,string 提供了非常丰富的查找函数。其列表如下:
( n9 _- {* e/ h3 C
函数名
描述
find查找
rfind反向查找
find_first_of查找包含子串中的任何字符,返回第一个位置
find_first_not_of查找不包含子串中的任何字符,返回第一个位置
find_last_of查找包含子串中的任何字符,返回最后一个位置
find_last_not_of查找不包含子串中的任何字符,返回最后一个位置

1 W. B, `' X8 Z/ D4 e: S以上函数都是被重载了4次,以下是以find_first_of 函数为例说明他们的参数,其他函数和其参数一样,也就是说总共有24个函数。
8 ^7 L3 s, g, R; n5 x( [9 L
- S! R4 C$ ?$ u$ h" G/ b, S
* X! l9 z" f8 N/ j
  • 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)  % ~8 }  [4 L9 {5 @' m

/ G/ @3 Y, o3 N& w0 i3 D, V6 n8 p  Dsize_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)
9 d4 D0 G& \" Y4 w9 @
+ z8 T9 V) B1 V# l所有的查找函数都返回一个size_type类型,这个返回值一般都是所找到字符串的位置,如果没有找到,则返回string::npos。有一点需要特别注意,所有和string::npos的比较一定要用string::size_type来使用,不要直接使用int 或者unsigned int等类型。其实string::npos表示的是-1, 看看头文件:0 h1 p% v8 D( g' v6 S1 z! [
# @% _! F2 e$ i4 {6 v2 s0 Q; Y
! `9 P) ^! I7 [  d' V
  • 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;  ; G* a  A4 `  V& e+ @, M. @
, k6 r* K* }6 V: {
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;
7 j' m8 p( z5 |* C' d. H" Y/ h( }4 F! v2 Y6 {
find 和 rfind 都还比较容易理解,一个是正向匹配,一个是逆向匹配,后面的参数pos都是用来指定起始查找位置。对于find_first_of 和find_last_of 就不是那么好理解。
find_first_of 是给定一个要查找的字符集,找到这个字符集中任何一个字符所在字符串中第一个位置。或许看一个例子更容易明白。
有这样一个需求:过滤一行开头和结尾的所有非英文字符。看看用string 如何实现:

, p$ ]2 J# P2 t) n- M( ]9 a! d" L% p/ G; u  w9 Z! j) M
  • #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;  
  • }  ! B1 B8 N- b. ^! A% K, Q5 }4 H2 F

' V: `" ^+ t$ }1 g$ _4 M) l! A$ p7 Y#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;}
+ X, s: w% D5 I0 U( j4 A
' Q' c' O1 t: ]1 j: R9 B2 W' k
6 F  d8 e  t. g& R4 S! j" v9 g% l: O( w" E) T% u# j
该会员没有填写今日想说内容.
回复

使用道具 举报

发表回复

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

返回列表 本版积分规则

  • 发布新帖

  • 在线客服

  • 微信

  • 客户端

  • 返回顶部

  • x
    温馨提示

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

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

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

    我知道了