先看一种很多人日常使用错误方式
string str("hello world");
int pos=str.find_first_of("h");
if(pos!=string::npos) // 或者 if(pos!=-1)
{..
....// 查找到了
} //不存在是find返回-1
这样的使用,结果是正常的,但并没有很好的理解string find函数的返回类型和string::npos真正的值。
string::find这类型的函数,返回值类型都是string::size_type, 而string::size_type其实是一种unsigned int类型。
find的结果记录匹配的位置,或者返回一个名为string::npos 的特殊值,说明查找没有匹配。
string 类将 npos 定义为保证大于任何有效下标的值。string::npos的值是无符号型类型的,其值是(unsigned int)(-1),也就是4294967295
所以正确的用法应该是:
string str("hello world");
string::size pos=str.find_first_of("h");
if(pos!=string::npos)
{..
....// 查找到了
} //不存在是find返回string::npos
由上面可以看出,string::npos的值是-1并不准确,string::npos的值是无符号型类型的,其值是(unsigned int)(-1),也就是4294967295,但是和int 类型的-1比较结果是true,所以使用的时候,认为其值是int类型的-1不会影响结果.
一种注意的问题
c++中的string,有一个方法是find(),每一个c++程序猿知道该函数的作用,但是,未必每一个c++程序猿都能正确的使用该函数
- string str = "Welcome to China";
- string str2 = "China";
- int index = str.find(str2);
- string str = "東方红|太阳升";
- string str2 = "|";
- int index = str.find(str2);
现在,你感觉到疑惑了,一个汉字两个字节,“東方红”用了6个字节,“|”的位置正好是6.怎么可能等于1呢!
问题就出在一个汉字占两个字节。”|“在ascii码表中的ascii值是124。而”東“这个字的第二个字节,恰好是124,因此,程序返回了1.
诸位看官,现在明白究竟是怎么一回事了吧,这种情况是很特殊的情况,平时很难遇到,笔者还遇到过更奇葩的情况,那个时候,为了检查字符串是否包含了不常用的字符而使用find()函数,待检查的字符都是双字节的,结果呢,源字符串的两个相邻汉字各取一个字节,恰好是一个待检查字符。就是从那个时候开始,我知道了这个坑,可以肯定,在所有介绍该函数的文章中,你很难看到这个坑,因为,它实在是太不明显了。