2

このクラスがあるとします (std::Vector から継承されています。これは単なる例です)。

#include <vector>

using namespace std;

template <class T>
class C : public vector<T> {

    // I don't want to use static keyword
    void transformation(T i) {
        i *= 100;
    }

    public:   
    void method() {
        for_each(this->begin(), this->end(), transformation);
    }
};

int main() {
    C<double> c;
    for (int i=-3; i<4; ++i) {
        c.push_back(i);
    }

    c.method();
}

クラス自体の中でクラスメソッドを使用して for_each を呼び出すにはどうすればよいですか? static キーワードを使用できることはわかっていますが、 static を使用せずに関数オブジェクトを使用する方法は他にありますか?

コンパイル中に次のエラー メッセージが表示されます。

for_each.cc:21:55: エラー: 'C::transformation' を型 'void (C::)(double)' から型 'void (C::*)(double)' に変換できません for_each(this-> begin(), this->end(), 変換);

.*またはどこかに追加する必要があると思います->*が、場所と理由がわかりません。

4

3 に答える 3

15

C++11バインドソリューション:

std::for_each(this->begin(), this->end(),
      std::bind(&C::transformation, this, std::placeholders::_1));

C++11ラムダソリューション:

std::for_each(this->begin(), this->end(),
      [this] (T& i) { transformation(i); });

C++14汎用ラムダソリューション:

std::for_each(this->begin(), this->end(),
      [this] (auto&& i) { transformation(std::forward<decltype(i)>(i)); });

C++98 bind1st+mem_funソリューション:

std::for_each(this->begin(), this->end(),
      std::bind1st(std::mem_fun(&C::transformation), this));

注: this->begin() and の呼び出しは、OP のコードではテンプレート化された基本クラスのメンバー関数であるという理由だけでthis->end()修飾されます。this->そのため、これらの名前は主にグローバル名前空間で検索されます。その他の出現thisは必須です。

于 2014-09-29T11:49:06.303 に答える
4

まず、標準コンテナーから継承しないでください。継承されるように設計されていません (仮想デストラクタなどはありません)。

第二に、あなたの問題に関しては、メンバー関数へのポインターが関数へのポインターと同じではないためです。その理由は、メンバー関数にはthis、関数内のポインターになる最初のパラメーターが隠されているためです。それを解決する最も簡単な方法は、関数を作成することですstatic

別の解決策はstd::bind、C++11 に付属の関数を使用することです。

for_each(this->begin(), this->end(),
    std::bind(&C::transformation, this, std::placeholders::_1));

C++ 11 を持っていない場合(質問にそのようにタグを付けたとしても)、おそらくstd::mem_funorで何かが動作する可能性がありますstd::bind1st

于 2014-09-29T11:38:43.440 に答える
0

thisポインターをバインドする必要があります。

public:   
void method() 
{
    for_each(this->begin(), this->end(), bind(&C::transformation, this, placeholders::_1));
}
于 2014-09-29T11:40:20.157 に答える