最初の問題は、std::find()
値を一致させようとすることです。つまり、 で置き換える必要がありstd::find()
ますstd::find_if()
。やり方は簡単です。
次の問題は、それboost::regex_match
が 1 つの関数ではなく、一連の関数であることです。std::bind2nd()
この家族のどのメンバーと対戦したいのかわかりません。また、明らかに使用したい関数オーバーロードは、2 つではなく 3 つの引数を取ります。型の最後の引数boost::match_flag_type
はデフォルトです。これを使用して動作するようにstd::bind()
しました:
std::bind(static_cast<bool (*)(std::string const&,
boost::regex const&,
boost::match_flag_type)>(&boost::regex_match),
std::placeholders::_1, re);
本当に使いたい場合std::bind2nd()
は、単純な転送関数を作成するのがおそらく最も簡単です:
bool my_regex_match(std::string s, boost::regex const& r) {
return boost::regex_match(s, r);
}
void f() {
boost::regex re("tryme");
std::ifstream iss(file.txt);
std::find_if(std::istream_iterator<std::string>(iss),
std::istream_iterator<std::string>(),
std::bind2nd(std::ptr_fun(&my_regex_match), re));
}
テンプレートは実際にはstd::bind2nd()
生の関数ポインターでは機能しません。std::ptr_fun()
これが、使用する必要がある理由です。一般に、呼び出された標準関数のいずれかを*_fun()
使用する必要がある場合、実際には楽しみが停止します。これらの関数は、参照によって引数を取る関数に対処できません。したがって、引数を値でmy_regex_match()
受け取ります。それ以外の場合は、参照への参照を引数として受け取る関数オブジェクトを作成しようとします。これが、 またはを使用するもう 1 つの理由です。std::string
std::bind2nd()
std::bind()
boost::bind()