2015-02-05 149 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; 
} 

將工作代替,但在許多情況下效率較低。