草庐IT

my_options

全部标签

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在空访问的情况下抛出的类,但这是我的偏执狂。如果您希望返回拷贝

c++ - std::optional 从方法返回可选值的最佳替代方案? (使用 C++98/C++11/C++14)

显然,std::optional如果使用C++17或boost(另见GOTW#90),是从函数返回可选值的最佳选择std::optionalpossiblyFailingCalculation()但是,如果一个人被旧版本卡住(并且不能使用boost),那么最好的选择是什么?为什么?我看到了几个选项:STL智能指针(仅限C++11)std::unique_ptrpossiblyFailingCalculation();(+)与可选的用法几乎相同(-)对非多态类型或内置类型的智能指针感到困惑与bool配对std::pairpossiblyFailingCalculation();旧式boo

c++ - 用于比较原始类型的 std::optional 的有趣程序集

Valgrind在我的一个单元测试中快速有条件的跳转或移动取决于未初始化的值。检查程序集,我意识到以下代码:booloperator==(MyTypeconst&left,MyTypeconst&right){//...somecode...if(left.getA()!=right.getA()){returnfalse;}//...somecode...returntrue;}在哪里MyType::getA()const->std::optional,生成以下程序集:0x00000000004d9588:xoreax,eax0x00000000004d958a:cmpBYTEPTR

node.js - 错误 : options. uri 是必需的参数

我正在使用node.jsv4.6.0和最新版本的express、request和body-parser,但我得到一个我无法修复的错误代码,有什么想法吗?这是我的代码:varexpress=require('express');varrequest=require('request');varbodyparser=require('body-parser');varapp=express();app.use(bodyparser.urlencoded({extended:true}))varwebhook=process.env.DISCORD_WEBHOOK;app.get('/',(

node.js - 奇怪的 Mongoose schema.js 错误 - `options` 不能用作模式路径名

在我的架构中,如果我有options在metrics:[{options:{}}]那么我得到:/home/one/cloudimageshare-monitoring/project/node_modules/mongoose/lib/schema.js:282thrownewError("`"+path+"`maynotbeusedasaschemapathname");^Error:`options`maynotbeusedasaschemapathname但是,如果将options更改为任何其他单词...例如qoptions...。那么错误就会消失。为什么会这样?varmongo

javascript - Node.js/v8 : How to make my own snapshot to accelerate startup

我有一个node.js(v0.6.12)应用程序,它从评估Javascript文件startup.js开始。评估startup.js需要很长时间,如果可能的话,我想将它“烘焙”到Node的自定义构建中。与Node一起分发的v8源目录node/deps/v8/src包含一个几乎可以用来执行此操作的SconScript。在第302行,我们有LIBRARY_FILES='''runtime.jsv8natives.jsarray.jsstring.jsuri.jsmath.jsmessages.jsapinatives.jsdate.jsregexp.jsjson.jsliveedit-de

node.js - 参数错误,node.js 中的 options.body?

我不知道是什么问题,请帮助解决这个问题。当我发布数据时,终端上会显示以下错误。附上代码也是。Error:Argumenterror,options.body.atRequest.init(/usr/lib/nodejs/request/index.js:351:13)atnewRequest(/usr/lib/nodejs/request/index.js:124:8)atObject.request(/usr/lib/nodejs/request/index.js:1279:11)atRequest._callback(/var/www/html/nodeproject/hellow