параметр queue<string> ? Делать static_cast? Или сделать функцию шаблонной где контейнер для queue шаблонный?
Второе, разумеется.
А помогите написать такой шаблон пожалуйста. Так не получается: template <typename C> void Foo(queue<string, C<string>> &q);
Недавно по аналогичному поводу писал. Обычный typename элиасит тип, а Вам нужен шаблон, т.е.: template < template < typename > typename C > void Foo(queue<string, C<string>> &q); Edit: Добавлю сразу разъясняющего материала. template < typename > struct Template; struct Typename; /* ... */ template < typename > struct ExampleA; template < template < typename > typename > struct ExampleB; template < typename, template < typename > typename > struct ExampleC; /* ExampleA<Typename> -- ok ExampleA<Template> -- error ExampleB<Typename> -- error ExampleB<Template> -- ok ExampleC<Typename, Template> -- ok ExampleC<Template, Typename> -- error */ Надеюсь, так понятнее (если вдруг не было).
Что-то не получается. Выдает ошибку: 'void Foo(std::queue<std::string,C<std::string>> &)': could not deduce template argument for 'std::queue<std::string,C<std::string>> &' from 'std::queue<std::string,std::deque<std::string,std::allocator<std::string>>>' template <template <typename> typename C> void Foo(queue<string, C<string>> &q) {} queue<string> q; Foo(q);
Для C<> требуется два шаблонных параметра (второй под аллокатор). template < template < typename, typename > /* or < typename... > */ typename C >
Так тоже не работает. 'C': too few template arguments
Если так делать, template <template <typename...> typename C> void Foo(queue<string, C<string>> &q) {} queue<string> q; Foo(q); то ошибка: 'void Foo(std::queue<std::string,C<std::string>> &)': could not deduce template argument for 'std::queue<std::string,C<std::string>> &' from 'std::queue<std::string,std::deque<std::string,std::allocator<std::string>>>'
Это я Вам глупостей наговорил: Вам на уровне определения шаблона (в шаблоне, C который) потребуется предоставить параметр по умолчанию (для второго typename), сообразный std::list (стандартный аллокатор от string т.е.), в таком случае.
Да, так работает template <class Container = std::deque<string>> void Foo(queue<string, Container> &q) {}
А обязательно в этом случае шаблонный параметр по-умолчанию указывать?
В таком - нет, кроме того, шаблон в качестве параметра там тоже не нужен, если тип элемента фиксирован (typename достаточно, но пытаться параметризировать его не нужно и нельзя).
Ага, вижу. Можно просто template <class Container> void Foo(queue<string, Container> &q) {}
Да. Но изначальная попытка Container<string>, разумеется, невозможна, поскольку Container - элиас на тип, а не на шаблон.
Обсуждают сегодня