我正在尝试比较常量引用和具有相同类型的非常量可选对象。我有一个类型NonCopy
,它是不可复制的
#include <iostream>
#include <boost/optional.hpp>
struct NonCopy {
NonCopy() { }
NonCopy(const NonCopy&) = delete;
NonCopy& operator=(const NonCopy&) = delete;
};
int main()
{
NonCopy nc;
const NonCopy& object = nc;
boost::optional<NonCopy&> object2 = nc;
if (!object2 && object2.get() != object) {
std::cout << "not equal?\n";
}
}
哪个收益
error: no match for ‘operator!=’ (operand types are ‘boost::optional_detail::types_when_is_ref<NonCopy&>::raw_type {aka NonCopy}’ and ‘const NonCopy’)
我尝试了主题的多种变体,包括
if (object2 && const_cast<const NonCopy&>(object2.get()) != object)
这会产生一个非常有趣的错误
error: no match for ‘operator!=’ (operand types are ‘const NonCopy’ and ‘const NonCopy’)
并在boost::optional<NonCopy>
上列出!=的候选人(例如bool boost::operator!=(const boost::optional<NonCopy>&, const boost::optional<NonCopy>&)
),而不是NonCopy
。{/ p>
答案 0 :(得分:5)
由于object2.get()
返回NonCopy&
,因此您的示例有效地简化为:
NonCopy nc;
const NonCopy& object = nc;
NonCopy& object2 = nc;
object != object2; // error: no match for operator!=
这仅表示您的类型NonCopy
没有operator!=
。实现它,你的代码将编译。 boost::optional
与此无关。
虽然请注意您正在检查:
if (!object2 && object2.get() != object)
^^^^^^^^ ^^^^^^^^^^^^^
object2 is none, but get it anyway?
这是未定义的行为。