5

我想知道是否有一种优雅的方法可以将 aboost::optional<A>转换为boost::optional<B>whenB可以从 构造A,尽管是明确的。这有效:

# include <boost/optional.hpp>

class Foo
{
  int i_;
public:
  explicit Foo(int i) : i_(i) {}
};

int main()
{
  boost::optional<int> i;
  ... // i gets initialized or not
  boost::optional<Foo> foo;
  foo = boost::optional<Foo>(bool(i), Foo(i.value_or(0 /*unused value*/)));
  return 0;
}

但是需要在其中放入一些永远不会使用的值似乎很尴尬。有更好的建议吗?

4

1 回答 1

9
template<class T, class U>
boost::optional<T> optional_cast( U&& u ) {
  if (u) return T(*std::forward<U>(u));
  else return {};
}

也可以有趣地使用指针。

int main() {
  boost::optional<int> i;
  ... // i gets initialized or not
  boost::optional<Foo> foo = optional_cast<Foo>(i);
  return 0;
}

在 C++03 中

template<class T, class U>
boost::optional<T> optional_cast( U const& u ) {
  if (u) return T(*u);
  else return boost::none;
}

将改为工作,但在许多情况下效率较低。

于 2015-02-05T15:10:01.373 回答