我想通过第一项初始化基类,形成一个包含基类的向量,例如:
struct Base { ... };
struct Derived : public Base
{
Derived(const Base& baseClass)
: Base(baseClass)
{
}
Derived(const std::vector<Base*>& listOfBaseClass)
: Base(*(listOfBaseClass[0]))
{
}
};
当listOfBaseClass
向量为空时,此解决方案失败。怎么能防止这种情况。这是简化的例子,所以
像这样调用基类构造函数:
std::vector<Base> baseClasses;
if(!baseClasses.empty())
{
Derived myDerived(baseClasses[0]);
}
这不是我的问题的解决方案。提前谢谢。
答案 0 :(得分:4)
如果列表为空,则抛出异常:
: Base(listOfBaseClass.empty()
? throw std::invalid_argument("Missing base class")
: *(listOfBaseClass[0])
)
请求的非例外变体:
: Base(( (listOfBaseClass.empty() && exit(0)),
*(listOfBaseClass[0])
))
答案 1 :(得分:3)
Derived(const std::vector<Base*>& listOfBaseClass)
: Base(*(listOfBaseClass->at(0)))
{
}
“at”提供异常安全性。如果n超出范围,它会抛出out_of_range。