Это компилирует:
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;
}
ОБНОВИТЬ
Если я попробую следующее:
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
Это досадная проблема, у нас тоже было некоторое время раньше. Мы исправили это с помощью convert_to_container
метод:
Constructor c(boost::assign::list_of(1)(2).convert_to_container<std::vector<int> >() );
Есть больше проблем с станд :: список используя в конструкторе тоже. Увидеть Передача std :: list в конструктор с использованием boost’s list_of не компилируется за соответствующий ответ.
Я использую этот шаблон для создания временного экземпляра 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;
}