PLM之家PLMHome-工业软件与AI结合践行者

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

[复制链接]

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

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

mildcat 楼主

2014-3-9 12:47:32

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

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

x
由于查找是使用最为频繁的功能之一,string 提供了非常丰富的查找函数。其列表如下:7 Q' |% ]7 _' q8 k) B) N
函数名
描述
find查找
rfind反向查找
find_first_of查找包含子串中的任何字符,返回第一个位置
find_first_not_of查找不包含子串中的任何字符,返回第一个位置
find_last_of查找包含子串中的任何字符,返回最后一个位置
find_last_not_of查找不包含子串中的任何字符,返回最后一个位置
% ~! D! t, n) H
以上函数都是被重载了4次,以下是以find_first_of 函数为例说明他们的参数,其他函数和其参数一样,也就是说总共有24个函数。# d) E, C# E# J! l

2 \+ v) O0 t2 m3 Y) m1 y5 T' y2 {- m& x: }/ n+ l( g6 k* |4 g. y
  • 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)  
    . o4 B: B! b, Q8 h* b1 t
; P  |4 F  ]2 v" p( k6 g$ W
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)
* M& ]9 O& w" _3 J) p
- }) H. C3 S6 n& |所有的查找函数都返回一个size_type类型,这个返回值一般都是所找到字符串的位置,如果没有找到,则返回string::npos。有一点需要特别注意,所有和string::npos的比较一定要用string::size_type来使用,不要直接使用int 或者unsigned int等类型。其实string::npos表示的是-1, 看看头文件:/ ?6 S* P. g  l
# j/ X$ W' ]  f
2 _8 E' R9 \9 y, C
  • 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;  
    9 i$ ?! D: m) Z3 ?2 X/ j( O/ t$ S
3 @6 f0 Y+ q: y- S+ z
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; 5 w  I3 \( Y* I

+ l7 H# `" t$ K; Z0 T" [
find 和 rfind 都还比较容易理解,一个是正向匹配,一个是逆向匹配,后面的参数pos都是用来指定起始查找位置。对于find_first_of 和find_last_of 就不是那么好理解。
find_first_of 是给定一个要查找的字符集,找到这个字符集中任何一个字符所在字符串中第一个位置。或许看一个例子更容易明白。
有这样一个需求:过滤一行开头和结尾的所有非英文字符。看看用string 如何实现:

/ S5 v4 H# f( ~! b8 l0 O7 d9 w6 W( ^1 X; R# D! V8 k; m5 S5 z
  • #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;  
  • }  & H; l* _' U9 B+ d; A+ @
  f7 P$ c3 y: T1 z) _
#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;}# p* z) k1 Z& [7 V$ g& p( ?  X
  ]: k$ X4 r- F4 @9 c) h
, v) n1 H! `7 M5 [
1 u, z$ _: _& B! N6 p) `0 {
该会员没有填写今日想说内容.
回复

使用道具 举报

发表回复

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

返回列表 本版积分规则

  • 发布新帖

  • 在线客服

  • 微信

  • 客户端

  • 返回顶部

  • x
    温馨提示

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

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

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

    我知道了