3

我有这样的代码:

boost::optional<double> result = _ind1.Value() / _ind2.Value();

每个 argboost::optional<double>也是:

boost::optional<double> Value() {
    return value;
}

错误是:

Error 1 error C2676: binary '/' : 'boost::optional<T>' does not define this operator or a conversion to a type acceptable to the predefined operator 2 IntelliSense: no operator "/" matches these operands operand types are: boost::optional<double> / boost::optional<double>

我知道似乎只是没有定义部门。我希望结果是boost::none如果两个参数中的任何一个是none- 否则我希望它是正常的双除法。我应该自己写这个吗?

4

1 回答 1

11

当然,像除法这样简单的运算也是支持的。

但你并没有试图将双打分开。你试图划分boost::optional<double>s 这是一个完全不同的故事。

如果需要,可以为此定义除法运算符。它可能看起来像(未经测试):

template<typename T>
boost::optional<T> operator/(const boost::optional<T>& a, const boost::optional<T>& b)
{
    if(a && b) return *a / *b;
    else return boost::optional<T>();
}

在 C++11 中(代码由 Yakk 提供):

template<class T,class U> struct divide_result {
  typedef typename std::decay<decltype(std::declval<T>()/std::declval<U>())>::type;
};
template<class T, class U> using divide_result_t=typename divide_result<T,U>::type;
template<typename T,typename U>
boost::optional<divide_result_t<T,U>> operator/(const boost::optional<T>& a, const boost::optional<U>& b)
{
    if(a && b) return *a / *b;
    else return boost::none;
}

我使用了一个模板,因为现在它也适用于 int、float 等。

于 2014-04-23T16:46:55.067 回答