同じ包含型の2つのコンテナー、たとえば2つstd::vector<int>
のs、またはastd::list<int>
とaを受け取る関数を作成しようとしていstd::vector<int>
ます。(しかし、astd::vector<int>
とstd::vector<double>
!)ではありません
それがどのように行われるべきかについて私はよくわからないので、私は最初にテストプログラムを書くことにしました:
#include <iostream>
#include <vector>
#include <list>
#include <algorithm>
struct vector_wrapper
{
template <typename T>
struct instance_wrapper
{
typedef typename std::vector<T> instance;
};
};
struct list_wrapper
{
template <typename T>
struct instance_wrapper
{
typedef typename std::list<T> instance;
};
};
template <typename T, typename C1, typename C2>
void move(typename C1::instance_wrapper<T>::instance& c1, typename C2::instance_wrapper<T>::instance& c2) // line 29
{
while (c1.size() > 0)
{
c2.push_front(c1.back());
c1.pop_back();
}
}
int main()
{
std::vector<int> v;
std::list <int> l;
v.reserve(10);
for (int i = 0; i < 10; ++i)
v.push_back(i);
move<int, vector_wrapper, list_wrapper>(v, l);
std::for_each(l.begin(), l.end(),
[] (int i) { std::cout << i << " "; }
);
std::cout << std::endl;
return 0;
}
-std=c++11
このコードでは、フラグを使用して、g++4.7で次のコンパイル時エラーが発生します。
metaclass.cpp:29:24: error: non-template 'instance_wrapper' used as template
... more ...
instance_wrapper
コンパイラがテンプレートとして正しく識別されないのはなぜですか?