1

処理パイプラインを実装しましたが、次のように改善したいと思います。

#include <iostream>

// buffers
struct src{}; struct b1{}; struct snk{};
// filters
struct f1
{
    f1( const src &, b1 & ) { std::cout << "f1( src, b1 )" << std::endl; }
};
struct f2
{
    f2( const b1 &, snk & ) { std::cout << "f2( b1, snk )" << std::endl; }
};
// the pipeline
template< typename... Filters >
struct pipeline
{
    template< typename LastB >
    pipeline( const LastB & )
    {}
};
template < typename T1, typename... T >
struct pipeline< T1, T... > : pipeline< T... >
{
    template< typename... Buffs, typename Bin, typename Bout >
    pipeline( Buffs &... buffs, Bin & bin, Bout & bout ) :
        pipeline< T... >( buffs..., bin ),
        filter( bin, bout )
    {
    }

    T1 filter;
};

int main()
{
    src ba; b1  bb; snk bc;

    pipeline< f1 > p1( ba, bb );
    pipeline< f1, f2 > p2( ba, bb, bc ); // the problem is in this line!
}

残念ながら、上記の例では次のエラーが発生します。

sda_variadic.cpp: In function 'int main()':
sda_variadic.cpp:40:39: error: no matching function for call to 'pipeline<f1, f2>::pipeline(src&, b1&, snk&)'
sda_variadic.cpp:40:39: note: candidates are:
sda_variadic.cpp:26:5: note: template<class ... Buffs, class Bin, class Bout> pipeline<T1, T ...>::pipeline(Buffs& ..., Bin&, Bout&)
sda_variadic.cpp:23:8: note: constexpr pipeline<f1, f2>::pipeline(const pipeline<f1, f2>&)
sda_variadic.cpp:23:8: note:   candidate expects 1 argument, 3 provided
sda_variadic.cpp:23:8: note: constexpr pipeline<f1, f2>::pipeline(pipeline<f1, f2>&&)
sda_variadic.cpp:23:8: note:   candidate expects 1 argument, 3 provided

このエラーの理由は何ですか?
修正方法は?

ちょっとした説明です。上記の例では、最初に unspecified のオブジェクトが作成されpipeline<>( snk )、次に特殊化されたオブジェクトが作成され、次に特殊化されたオブジェクトが作成されると予想されpipeline< f1 >(b1,snk)ますpipeline< f1, f2 >(src,b1,snk)
ところで、上記の例は 1 つのフィルター ( ) で機能することに注意してくださいpipeline< f1

4

1 に答える 1

4
template< typename... Buffs, typename Bin, typename Bout >
pipeline( Buffs &... buffs, Bin & bin, Bout & bout ) :
    pipeline< T... >( buffs..., bin ),
    filter( bin, bout )
{
}

関数パラメータ パック ( Buffs) は最後の位置にないため、推測できません。14.8.2.1 関数呼び出し [temp.deduct.call] パラグラフ 1 からのテンプレート引数の推定:

  1. [...] parameter-declaration-list の最後に出現しない関数パラメーター パックの場合、パラメーター パックの型は非推定コンテキストです。[...]

テンプレート パラメーターをコンストラクターに明示的に渡すことはできないため、まったく呼び出すことはできません (ただし、問題には関係ありません)。

std::tuple次のようにコンストラクターを呼び出すように、可変引数を操作するために使用することをお勧めしますpipeline(std::forward_as_tuple(b0, b1, b2), in, out)。空のタプルが最後のステージに渡されます。

于 2011-10-22T08:10:35.550 に答える