std::vector
имеет функцию-член at()
как безопасную альтернативу operator[]
, поэтому применяется связанная проверка и не создаются ничтожные ссылки:
void foo(std::vector<int> const&x)
{
const auto&a=x[0]; // What if x.empty()? Undefined behavior!
const auto&a=x.at(0); // Throws exception if x.empty().
}
Однако std::unique_ptr
не хватает соответствующей функциональности:
void foo(std::unique_ptr<int> const&x)
{
const auto&a=*x; // What if bool(x)==false? Undefined behavior!
}
Было бы здорово, если бы std::unique_ptr
имела такую безопасную альтернативу, скажем, член ref()
(и cref()
), который никогда не возвращает оборванную ссылку, а скорее генерирует исключение. Возможная реализация:
template<typename T>
typename add_lvalue_reference<T>::type
unique_ptr<T>::ref() const noexcept(false)
{
if(bool(*this)==false)
throw run_time_error("trying to de-refrence null unique_ptr");
return this->operator*();
}
Есть ли веская причина, почему стандарт не предоставляет такого рода вещи?