Использование boost:: assign:: list_of
Это компилируется:
std::vector<int> value = boost::assign::list_of(1)(2);
Но не это:
Constructor(std::vector<int> value)
{
}
Constructor (boost::assign::list_of(1)(2));
Есть ли однострочное решение для инициализации вектора, переданного конструктору?
Еще лучше, если конструктор копирует переменную класса, беря вместо нее ссылку:
Constructor(std::vector<int>& value)
{
_value = value;
}
UPDATE
Если я попробую следующее:
enum Foo
{
FOO_ONE, FOO_TWO
};
class Constructor
{
public:
Constructor(const std::vector<Foo>& value){}
};
Constructor c(std::vector<Foo>(boost::assign::list_of(FOO_ONE)));
Я получаю ошибку компилятора:
error C2440: '<function-style-cast>' : cannot convert from 'boost::assign_detail::generic_list<T>' to 'std::vector<_Ty>'
1> with
1> [
1> T=Foo
1> ]
1> and
1> [
1> _Ty=Foo
1> ]
1> No constructor could take the source type, or constructor overload resolution was ambiguous
Ответы
Ответ 1
Это раздражающая проблема, мы также имели некоторое время назад. Мы исправили его с помощью метода convert_to_container
:
Constructor c(boost::assign::list_of(1)(2).convert_to_container<std::vector<int> >() );
В конструкторе больше проблем с std:: list. См. Передача std:: list в конструктор с использованием boost_ list_of не компилирует для соответствующего ответа.
Ответ 2
Я использую этот шаблон для создания временного экземпляра std::vector на месте:
#include <vector>
namespace Util {
//init vector
template <typename ELEMENT_TYPE > struct vector_of
: public std::vector<ELEMENT_TYPE>
{
vector_of(const ELEMENT_TYPE& t)
{
(*this)(t);
}
vector_of& operator()(const ELEMENT_TYPE& t)
{
this->push_back(t);
return *this;
}
};
}//namespace Util
Использование будет выглядеть так:
Constructor (Util::vector_of<int>(1)(2));
Подпись конструктора будет выглядеть так:
Constructor(const std::vector<int>& value)
{
_value = value;
}