2015-02-05 145 views
3

我想知道是否有一种优雅的方式来将boost::optional<A>转换为boost::optional<B>,但B可以从A构建,虽然明确地说。这个作品:boost :: optional和类型转换

# 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; 
} 

但需要放在那里永远不会使用的一些价值似乎尴尬。有什么更好的建议?

回答

6
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; 
} 

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