问题
直接上问题,我今天再刷题的时候,碰到了下面的编译错误。
reference to non-static member function must be called
先来看错误代码:
class Solution {
public:
string ReverseSentence(string str) {
typedef string::const_iterator const_iter;
const_iter b = str.begin();
const_iter e = str.end();
string ret;
int first = 1;
while( b != e ){
b = find_if( b, e, legal );
if( b < e ){
const_iter after = find_if( b, e, illegal ); // 这里的调用出了问题,编译出错reference to non-static member function must be called
if( ret != "" ) ret = string(b, after) + " " + ret;
else ret = string(b, after) + ret;
b = after;
}
else{
if( 1 == first ) return str;
else first = 2;
}
}
return ret;
}
private:
bool legal( char ch ){ return !illegal(ch); } // 这里是问题
bool illegal( char ch ){ return isspace(ch); }
};
解决
分析上面的错误,应该说的是,find_if的第三个参数应该调用一个non static函数,这是什么原因?我们来看下find_if的代码
template<class InputIterator, class UnaryPredicate>
InputIterator find_if (InputIterator first, InputIterator last, UnaryPredicate pred)
{
while (first!=last) {
if (pred(*first)) return first;
++first;
}
return last;
}
第三个谓词pred是一个非成员函数,因为pred的调用过程只有一个参数,就是*first。但是,对于像bool legal(char ch)这样的成员函数,它是属于类的,所以调用它必须需要对象才可以,这是因为bool legal这样的函数完整的标签是:
bool legal( Solution* this, char ch );
也就是它有一个implicit parameter,这才导致它无法被find_if这样的函数调用,主要是参数不匹配。当然,把这个函数改成static即可。