2017-02-07 7 views
2

В следующем коде я пытаюсь выделить класс A для базового блока, если параметр шаблона T имеет значение B<m>.Некорректная реализация шаблона специализации

#include <array> 
#include <iostream> 

template <std::size_t m> 
struct B 
{ 
    std::array<double,m> arr; 
}; 


template <std::size_t n, typename T> 
struct A 
{ 
    std::array<T,n> arr; 
    const static int inner_dim = T::inner_dim; 
}; 

template <std::size_t n > 
template <std::size_t m> 
struct A<n,B<m>> 
{ 
    std::array<B<m>,n> arr; 
    const static int inner_dim = m; 
}; 


int main(int argc, char *argv[]) 
{ 
    A<5,A<4,B<3>>> a; 
    std::cout << a.inner_dim << std::endl; 

    A<5,B<4>> b; 
    std::cout << b.inner_dim << std::endl; 

    return 0; 
} 

Однако при конкретизации в основном, я получаю следующее сообщение об ошибке, когда я компилирую с г ++ 5.4:

$ g++ -Wall --std=c++11 specialization.cc 
specialization.cc: In instantiation of ‘const int A<4ul, B<3ul> >::inner_dim’: 
specialization.cc:15:20: required from ‘const int A<5ul, A<4ul, B<3ul> > >::inner_dim’ 
specialization.cc:30:18: required from here 
specialization.cc:15:20: error: ‘inner_dim’ is not a member of ‘B<3ul>’ 
    const static int inner_dim = T::inner_dim; 
        ^
specialization.cc: In instantiation of ‘const int A<5ul, B<4ul> >::inner_dim’: 
specialization.cc:33:18: required from here 
specialization.cc:15:20: error: ‘inner_dim’ is not a member of ‘B<4ul>’ 

Вроде используется только общее определение, никогда специализации. Как я могу гарантировать, что правильная специализация будет создана?

+0

примечание: лязг отвергает попытки специализации –

ответ

6

Моя догадка

template <std::size_t n > 
template <std::size_t m> 
struct A<n,B<m>> 

должен быть

template <std::size_t n, std::size_t m> 
struct A<n,B<m>> 
+0

Да, это так. Weird. Я уверен, что раньше это делал. Благодаря! – kalj