構成コピー(1.で実行可能copy_if)を実行したいが、値のコンテナーからそれらの値へのポインターのコンテナー(2.で実行可能transform)を実行したい場合に、ユースケースが出現しました。
利用可能なツールでは、2ステップ未満でそれを行うことはできません:
#include <vector>
#include <algorithm>
using namespace std;
struct ha { 
    int i;
    explicit ha(int a) : i(a) {}
};
int main() 
{
    vector<ha> v{ ha{1}, ha{7}, ha{1} }; // initial vector
    // GOAL : make a vector of pointers to elements with i < 2
    vector<ha*> ph; // target vector
    vector<ha*> pv; // temporary vector
    // 1. 
    transform(v.begin(), v.end(), back_inserter(pv), 
        [](ha &arg) { return &arg; }); 
    // 2. 
    copy_if(pv.begin(), pv.end(), back_inserter(ph),
        [](ha *parg) { return parg->i < 2;  }); // 2. 
    return 0;
}
我々は呼び出すことができますofcourseのremove_if上pv、一時の必要性を排除し、より良いまだしかし、それがために難しいことではありません実装し、このような何か(単項演算のために):
template <
    class InputIterator, class OutputIterator, 
    class UnaryOperator, class Pred
>
OutputIterator transform_if(InputIterator first1, InputIterator last1,
                            OutputIterator result, UnaryOperator op, Pred pred)
{
    while (first1 != last1) 
    {
        if (pred(*first1)) {
            *result = op(*first1);
            ++result;
        }
        ++first1;
    }
    return result;
}
// example call 
transform_if(v.begin(), v.end(), back_inserter(ph), 
[](ha &arg) { return &arg;      }, // 1. 
[](ha &arg) { return arg.i < 2; });// 2.
- 利用可能なC ++標準ライブラリツールを使用したより洗練された回避策はありますか?
- transform_if図書館に存在しない理由はありますか?既存のツールの組み合わせは十分な回避策であり、および/またはパフォーマンスに関して適切に動作していると見なされていますか?
transform_ifは、「特定の述語が満たされた場合にのみ変換する」ことを意味します。あなたが欲しいもののより説明的な名前は次のようになりますcopy_if_and_transform!