草庐IT

extract_options

全部标签

c++ - boost::optional 到 bool 的转换

如何防止这段代码的最后一行被编译?#includeintmain(){typedefboost::optionalint_opt;int_optopt=0;boolx=opt;//最后一行不检查opt包含的int值,而是编译为类型转换为bool,这似乎不是用户想要的。安全的bool习语似乎与此相关? 最佳答案 boost::optional的全部意义在于启用这样的代码:voidfunc(boost::optionaloptionalArg){if(optionalArg){doSomething(*optionalArg);}}所以

Mongodb错误: Can't extract geo keys from object,畸形几何?

mongodb2.4.3出现以下错误无法从对象、格式错误的几何图形中提取地理键?{type:"Polygon",coordinates:[[[103.8324334524412,1.284232321447769],[103.8342325475588,1.284232321447769],[103.8342325469261,1.282433678236006],[103.8324334530738,1.282433678236006]]]}有人可以帮我理解这个问题吗?它看起来像一个有效的geoJSON对象。我的索引是2dsphere类型的。我正在运行的两个步骤是:collectio

Mongodb错误: Can't extract geo keys from object,畸形几何?

mongodb2.4.3出现以下错误无法从对象、格式错误的几何图形中提取地理键?{type:"Polygon",coordinates:[[[103.8324334524412,1.284232321447769],[103.8342325475588,1.284232321447769],[103.8342325469261,1.282433678236006],[103.8324334530738,1.282433678236006]]]}有人可以帮我理解这个问题吗?它看起来像一个有效的geoJSON对象。我的索引是2dsphere类型的。我正在运行的两个步骤是:collectio

c++ - std::optional::value_or() - 惰性参数评估

是否有可能以惰性方式评估std::optional::value_or(expr)参数,因此expr仅在没有的情况下计算值(value)?如果不是,什么是合适的替代品? 最佳答案 #includetemplatestructLazy{Ff;operatordecltype(f())()const{returnf();}};templateLazy(Ff)->Lazy;intmain(){std::optionalo;inti=o.value_or(Lazy{[]{return0;}});}DEMO

c++ - 为什么 optional<T&> 应该在分配时重新绑定(bind)?

关于optional的内容一直存在争议。和variant应该与引用类型有关,尤其是在分配方面。我想更好地理解围绕这个问题的辩论。optionalopt;opt=i;opt=j;//shouldthisrebindordoi=j?目前,决定是optional格式不正确,使variant::operator=如果任何类型是引用类型,则格式错误-回避参数并仍然为我们提供大部分功能。opt=j的论据是什么?应该重新绑定(bind)底层引用吗?换句话说,为什么应该我们实现optional像这样:templatestructoptional{T*ptr=nullptr;optional&opera

c++ - 如何使用 boost::program_options 接受可选标志?

我需要实现一个可选标志,例如-f/--flag。由于这是一个标志,因此没有关联的值。在我的代码中,我只需要知道是否设置了标志。使用boost::program_options的正确方法是什么? 最佳答案 一个方便的方法是使用bool_switch功能:boolflag=false;namespacepo=boost::program_options;po::options_descriptiondesc("options");desc.add_options()("flag,f",po::bool_switch(&flag),"de

c++ - 如何从 std::optional<T> 移动

考虑以下示例,我们解析数据并将结果传递给下一个函数:ContentParse(conststd::string&data);voidProcess(Contentcontent);intmain(){autodata=ReadData();Process(Parse(data));}现在让我们使用std::optional更改代码处理失败的解析步骤:optionalParse(conststd::string&data);voidProcess(Contentcontent);intmain(){autodata=ReadData();autocontent=Parse(data);i

c++ - boost::program_options - 是否可以强制执行强制标志?

我在我的程序中使用boost::program_options。我想强制使用某个标志。是否可以使用program_options来执行此操作,而它自己会强制执行此操作?即,抛出错误消息? 最佳答案 根据documentation您可以在选项描述中指定一个选项是必需的:options_descriptiondesc;desc.add_options()("help","producehelp")("count",value()->required(),"numberofexecutions");

c++ - 为什么移动 std::optional 不会重置状态

我很惊讶地发现std::optional的移动构造函数(以及相关的赋值)不会重置移动的可选值,如[19.6.3.1/7]其中指出“bool(rhs)未更改。”这也可以通过以下代码看出:#include#include#include#includeintmain(){std::optionalfoo{0};std::optionalbar{std::move(foo)};std::cout这似乎与标准库中的其他移动实例相矛盾,例如std::vector移动的容器通常以某种方式重置(在vector的情况下,它保证为空之后)使其“无效”,即使其中包含的对象本身已被移动。这个决策应该支持这个

c++ - 当你想实现一个可以返回 "nothing"的函数时,何时使用 boost::optional 以及何时使用 std::unique_ptr ?

据我了解,有两种方法可以实现有时不返回结果的函数(例如在ppl列表中找到的人)。*-我们忽略原始ptr版本,与bool标志配对,并在未找到版本时出现异常。boost::optionalfindPersonInList();或std::unique_ptrfindPersonInList();那么有什么理由比另一个更喜欢一个吗? 最佳答案 这取决于:您希望返回句柄还是拷贝。如果你想返回一个句柄:Person*boost::optional都是可接受的选择。我倾向于使用Ptr在空访问的情况下抛出的类,但这是我的偏执狂。如果您希望返回拷贝