C++中find函数的返回值是什么

发布网友

我来回答

4个回答

热心网友

返回找到的元素位置的迭代器或指针

找不到就返回超出数组尾部的第一个位置

热心网友

举个例子:
string str1( "Alpha Beta Gamma Delta" );
string::size_type loc = str1.find( "Omega", 0 );
if( loc != string::npos )
cout << "Found Omega at " << loc << endl;
else
cout << "Didn't find Omega" << endl;

热心网友

  代码示例:
  int
main()
{
string
s
=
"Alice
Bob
Charlie";
size_t
position;
position
=
s.find("none");
if
(position
>=
0)
cout
<<
"Found!
position
is
:
"
<<
position
<<
endl;
else
cout
<<
"Not
found!"
<<
endl;
}
  现象&后果
  程序运行结果输出"Found!
position
is
:
4294967295",但实际上所找的字符串"none"并不存在于字符串s中。
  Bug分析:
  程序的目的是,在源字符串s中查找目的字符串,若找到,则显示"Found",并返回目标子串在源字符串中的位置;反之,若未找到,则返回"Not
found"。string.find在未找到时会返回string::npos。
  在C++中常量npos是这样定义的:
  static
const
size_t
npos
=
-1;
  即常量npos定义的值为-1.
但又因为npos
的类型size_t是无符号整数类型,所以npos实际上是一个正数,并且是size_t类型的最大值。
  上述代码中,把find函数返回的值赋给size_t类型的变量position,而size_t类型的变量position是永远大于等于0,所以即使find返回npos,if条件也为true。
  正确的做法是在if条件中直接用npos作比较。
  正确代码:
  int
main()
{
string
s
=
"Alice
Bob
Charlie";
size_t
position;
position
=
s.find("none");
if
(position
!=
string::npos)
cout
<<
"Found!
position
is
:
"
<<
position
<<
endl;
else
cout
<<
"Not
found!"
<<
endl;
}

热心网友

  代码示例:
  int main()
{ string s = "Alice Bob Charlie";
size_t position;
position = s.find("none");
if (position >= 0)
cout << "Found! position is : " << position << endl;
else
cout << "Not found!" << endl; }

  现象&后果
  程序运行结果输出"Found! position is : 4294967295",但实际上所找的字符串"none"并不存在于字符串s中。
  Bug分析:
  程序的目的是,在源字符串s中查找目的字符串,若找到,则显示"Found",并返回目标子串在源字符串中的位置;反之,若未找到,则返回"Not found"。string.find在未找到时会返回string::npos。
  在C++中常量npos是这样定义的:
  static const size_t npos = -1;

  即常量npos定义的值为-1. 但又因为npos 的类型size_t是无符号整数类型,所以npos实际上是一个正数,并且是size_t类型的最大值。
  上述代码中,把find函数返回的值赋给size_t类型的变量position,而size_t类型的变量position是永远大于等于0,所以即使find返回npos,if条件也为true。
  正确的做法是在if条件中直接用npos作比较。
  正确代码:
  int main()
{ string s = "Alice Bob Charlie";
size_t position;
position = s.find("none");
if (position != string::npos)
cout << "Found! position is : " << position << endl;
else
cout << "Not found!" << endl; }

热心网友

返回找到的元素位置的迭代器或指针

找不到就返回超出数组尾部的第一个位置

热心网友

举个例子:
string str1( "Alpha Beta Gamma Delta" );
string::size_type loc = str1.find( "Omega", 0 );
if( loc != string::npos )
cout << "Found Omega at " << loc << endl;
else
cout << "Didn't find Omega" << endl;

热心网友

  代码示例:
  int
main()
{
string
s
=
"Alice
Bob
Charlie";
size_t
position;
position
=
s.find("none");
if
(position
>=
0)
cout
<<
"Found!
position
is
:
"
<<
position
<<
endl;
else
cout
<<
"Not
found!"
<<
endl;
}
  现象&后果
  程序运行结果输出"Found!
position
is
:
4294967295",但实际上所找的字符串"none"并不存在于字符串s中。
  Bug分析:
  程序的目的是,在源字符串s中查找目的字符串,若找到,则显示"Found",并返回目标子串在源字符串中的位置;反之,若未找到,则返回"Not
found"。string.find在未找到时会返回string::npos。
  在C++中常量npos是这样定义的:
  static
const
size_t
npos
=
-1;
  即常量npos定义的值为-1.
但又因为npos
的类型size_t是无符号整数类型,所以npos实际上是一个正数,并且是size_t类型的最大值。
  上述代码中,把find函数返回的值赋给size_t类型的变量position,而size_t类型的变量position是永远大于等于0,所以即使find返回npos,if条件也为true。
  正确的做法是在if条件中直接用npos作比较。
  正确代码:
  int
main()
{
string
s
=
"Alice
Bob
Charlie";
size_t
position;
position
=
s.find("none");
if
(position
!=
string::npos)
cout
<<
"Found!
position
is
:
"
<<
position
<<
endl;
else
cout
<<
"Not
found!"
<<
endl;
}

热心网友

返回找到的元素位置的迭代器或指针

找不到就返回超出数组尾部的第一个位置

热心网友

举个例子:
string str1( "Alpha Beta Gamma Delta" );
string::size_type loc = str1.find( "Omega", 0 );
if( loc != string::npos )
cout << "Found Omega at " << loc << endl;
else
cout << "Didn't find Omega" << endl;

热心网友

  代码示例:
  int
main()
{
string
s
=
"Alice
Bob
Charlie";
size_t
position;
position
=
s.find("none");
if
(position
>=
0)
cout
<<
"Found!
position
is
:
"
<<
position
<<
endl;
else
cout
<<
"Not
found!"
<<
endl;
}
  现象&后果
  程序运行结果输出"Found!
position
is
:
4294967295",但实际上所找的字符串"none"并不存在于字符串s中。
  Bug分析:
  程序的目的是,在源字符串s中查找目的字符串,若找到,则显示"Found",并返回目标子串在源字符串中的位置;反之,若未找到,则返回"Not
found"。string.find在未找到时会返回string::npos。
  在C++中常量npos是这样定义的:
  static
const
size_t
npos
=
-1;
  即常量npos定义的值为-1.
但又因为npos
的类型size_t是无符号整数类型,所以npos实际上是一个正数,并且是size_t类型的最大值。
  上述代码中,把find函数返回的值赋给size_t类型的变量position,而size_t类型的变量position是永远大于等于0,所以即使find返回npos,if条件也为true。
  正确的做法是在if条件中直接用npos作比较。
  正确代码:
  int
main()
{
string
s
=
"Alice
Bob
Charlie";
size_t
position;
position
=
s.find("none");
if
(position
!=
string::npos)
cout
<<
"Found!
position
is
:
"
<<
position
<<
endl;
else
cout
<<
"Not
found!"
<<
endl;
}

热心网友

  代码示例:
  int main()
{ string s = "Alice Bob Charlie";
size_t position;
position = s.find("none");
if (position >= 0)
cout << "Found! position is : " << position << endl;
else
cout << "Not found!" << endl; }

  现象&后果
  程序运行结果输出"Found! position is : 4294967295",但实际上所找的字符串"none"并不存在于字符串s中。
  Bug分析:
  程序的目的是,在源字符串s中查找目的字符串,若找到,则显示"Found",并返回目标子串在源字符串中的位置;反之,若未找到,则返回"Not found"。string.find在未找到时会返回string::npos。
  在C++中常量npos是这样定义的:
  static const size_t npos = -1;

  即常量npos定义的值为-1. 但又因为npos 的类型size_t是无符号整数类型,所以npos实际上是一个正数,并且是size_t类型的最大值。
  上述代码中,把find函数返回的值赋给size_t类型的变量position,而size_t类型的变量position是永远大于等于0,所以即使find返回npos,if条件也为true。
  正确的做法是在if条件中直接用npos作比较。
  正确代码:
  int main()
{ string s = "Alice Bob Charlie";
size_t position;
position = s.find("none");
if (position != string::npos)
cout << "Found! position is : " << position << endl;
else
cout << "Not found!" << endl; }

热心网友

  代码示例:
  int main()
{ string s = "Alice Bob Charlie";
size_t position;
position = s.find("none");
if (position >= 0)
cout << "Found! position is : " << position << endl;
else
cout << "Not found!" << endl; }

  现象&后果
  程序运行结果输出"Found! position is : 4294967295",但实际上所找的字符串"none"并不存在于字符串s中。
  Bug分析:
  程序的目的是,在源字符串s中查找目的字符串,若找到,则显示"Found",并返回目标子串在源字符串中的位置;反之,若未找到,则返回"Not found"。string.find在未找到时会返回string::npos。
  在C++中常量npos是这样定义的:
  static const size_t npos = -1;

  即常量npos定义的值为-1. 但又因为npos 的类型size_t是无符号整数类型,所以npos实际上是一个正数,并且是size_t类型的最大值。
  上述代码中,把find函数返回的值赋给size_t类型的变量position,而size_t类型的变量position是永远大于等于0,所以即使find返回npos,if条件也为true。
  正确的做法是在if条件中直接用npos作比较。
  正确代码:
  int main()
{ string s = "Alice Bob Charlie";
size_t position;
position = s.find("none");
if (position != string::npos)
cout << "Found! position is : " << position << endl;
else
cout << "Not found!" << endl; }

热心网友

返回找到的元素位置的迭代器或指针

找不到就返回超出数组尾部的第一个位置

热心网友

举个例子:
string str1( "Alpha Beta Gamma Delta" );
string::size_type loc = str1.find( "Omega", 0 );
if( loc != string::npos )
cout << "Found Omega at " << loc << endl;
else
cout << "Didn't find Omega" << endl;

热心网友

  代码示例:
  int
main()
{
string
s
=
"Alice
Bob
Charlie";
size_t
position;
position
=
s.find("none");
if
(position
>=
0)
cout
<<
"Found!
position
is
:
"
<<
position
<<
endl;
else
cout
<<
"Not
found!"
<<
endl;
}
  现象&后果
  程序运行结果输出"Found!
position
is
:
4294967295",但实际上所找的字符串"none"并不存在于字符串s中。
  Bug分析:
  程序的目的是,在源字符串s中查找目的字符串,若找到,则显示"Found",并返回目标子串在源字符串中的位置;反之,若未找到,则返回"Not
found"。string.find在未找到时会返回string::npos。
  在C++中常量npos是这样定义的:
  static
const
size_t
npos
=
-1;
  即常量npos定义的值为-1.
但又因为npos
的类型size_t是无符号整数类型,所以npos实际上是一个正数,并且是size_t类型的最大值。
  上述代码中,把find函数返回的值赋给size_t类型的变量position,而size_t类型的变量position是永远大于等于0,所以即使find返回npos,if条件也为true。
  正确的做法是在if条件中直接用npos作比较。
  正确代码:
  int
main()
{
string
s
=
"Alice
Bob
Charlie";
size_t
position;
position
=
s.find("none");
if
(position
!=
string::npos)
cout
<<
"Found!
position
is
:
"
<<
position
<<
endl;
else
cout
<<
"Not
found!"
<<
endl;
}

热心网友

  代码示例:
  int main()
{ string s = "Alice Bob Charlie";
size_t position;
position = s.find("none");
if (position >= 0)
cout << "Found! position is : " << position << endl;
else
cout << "Not found!" << endl; }

  现象&后果
  程序运行结果输出"Found! position is : 4294967295",但实际上所找的字符串"none"并不存在于字符串s中。
  Bug分析:
  程序的目的是,在源字符串s中查找目的字符串,若找到,则显示"Found",并返回目标子串在源字符串中的位置;反之,若未找到,则返回"Not found"。string.find在未找到时会返回string::npos。
  在C++中常量npos是这样定义的:
  static const size_t npos = -1;

  即常量npos定义的值为-1. 但又因为npos 的类型size_t是无符号整数类型,所以npos实际上是一个正数,并且是size_t类型的最大值。
  上述代码中,把find函数返回的值赋给size_t类型的变量position,而size_t类型的变量position是永远大于等于0,所以即使find返回npos,if条件也为true。
  正确的做法是在if条件中直接用npos作比较。
  正确代码:
  int main()
{ string s = "Alice Bob Charlie";
size_t position;
position = s.find("none");
if (position != string::npos)
cout << "Found! position is : " << position << endl;
else
cout << "Not found!" << endl; }

声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com