草庐IT

extract_options

全部标签

c++ - boost::program_options 可以使用 "-"以外的定界符吗?

我像这样使用boost::program_options:namespacepo=boost::program_options;po::options_descriptiondesc("Options");desc.add_options()("help,?","ShowOptions")("capture-file,I",po::value(),"CaptureFile")("capture-format,F",po::value()->default_value("pcap"),"CaptureFileFormat")("output-file,O",po::value()->de

c++ - std::optional 中不可复制的容器

我正在尝试将不可复制类型的(STL-)容器打包到std::optional,e。例如:classMyClass{MyClass(constMyClass&)=delete;};std::optional>optContainer;但是编译器(GCC7.2)提示error:useofdeletedfunction'MyClass::MyClass(constMyClass&)'{::new((void*)__p)_Up(std::forward(__args)...);}[...]note:declaredhereMyClass(constMyClass&)=delete;并在type_

c++ - 当我可以返回一个指针时,为什么要使用 boost::optional

关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭6年前。Improvethisquestion如果我有一个find函数,有时可能无法找到所需的东西,我倾向于让该函数返回一个指针,这样一个nullptr指示该东西没有找到。例如Student*SomeClass::findStudent(/**somecriteria.*/)如果Student存在,返回一个指向找到的Student对象的指针,否则返回nullptr。我也看到boost::optional也为此目的而提倡。例如。When

c++ - boost program_options 是如何工作的?

对我来说奇怪的是,boost的options_description使用多行代码,没有反斜杠、分号或逗号。我做了一些研究,但一无所获。(代码取自officialboost'stutorial):intopt;po::options_descriptiondesc("Allowedoptions");desc.add_options()("help","producehelpmessage")("optimization",po::value(&opt)->default_value(10),"optimizationlevel")("include-path,I",po::value>

c++ - 我可以使用 std::optional 进行错误处理吗?

关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。Improvethisquestion使用C++17我们得到了std::optional这是表达可空类型的有用包装器。我可以用它来处理错误吗?这样做很有吸引力:optionalCompute(){//...computesomethingvalid...returnstd::nullopt;//error!}这会是一个不错的选择吗?返回空指针不一样吗?人们报告的问题是,如果发生错误,您会丢失一条消息。所以返回一些状态码可能会更

c++ - 如何将 boost options_description 与十六进制输入一起使用?

我想有两个选项供程序运行,起始地址和结束地址,以便程序选项如下:--start_address0xc0000000--end_address0xffffffffoptions_description是否可以接受这样的十六进制输入?我是否必须将输入视为字符串并将它们转换为十六进制值。我现在有这个:po::options_descriptiondesc("Allowedoptions");desc.add_options()("help,h","displaythishelpmessage")("path,p",po::value(),"Executablefilepath")("star

c++ - 自动配置/自动制造 : How to avoid passing the "check" option to AC_CONFIG_SUBDIRS

我正在使用Autoconf构建我的C++项目。它使用第三方代码,这些代码也是在Autoconf/Automake的帮助下构建的。所以在我的configure.ac中有以下行:AC_CONFIG_SUBDIRS([subdirectoryname])一切正常,但我还使用该功能让测试在执行makecheck时自动进行-这也是由第三方代码完成的。因为这些测试需要一段时间,所以每次我想测试自己的代码时都执行它们很烦人。那么有没有办法避免check选项被传递给子目录的Makefile呢?更新:覆盖check-recursive似乎不是一个选项,因为我的顶级Makefile.am看起来(或多或少)

c++ - 什么是 diff b/w Includes in VC++ Directories options 和 Additional include directories in C++ -> General in Visual Studio

我尝试在工具->选项中的VC++目录->包含目录选项中添加包含目录,但在编译时出现错误-“找不到文件或目录”。一旦我添加到Projectproperties->Configurationproperties->C++->General->Additionalincludedirectories,我就可以成功编译。那么为什么VisualStudio有一个包含目录选项。为什么它用于?(我使用的是VisualStudio2010Beta1) 最佳答案 VisualStudio团队最近在他们的博客中解释了VS2010在包含目录方面与早期版本

c++ - 有什么能阻止 std::optional::value_or() 有条件地 noexcept 吗?

这是value_or()的定义来自C++17标准:templateconstexprTvalue_or(U&&v)const&;Effects:Equivalentto:returnbool(*this)?**this:static_cast(std::forward(v));Remarks:Ifis_copy_constructible_v&&is_convertible_visfalse,theprogramisill-formed.(右值重载类似)value_or的效果被描述为等同于returnbool(*this)?**this:static_cast(std::forward

c++ - 如何防止 boost::optional<T> 被错误地构造为 0?

boost::optional(1.51)提供了一种构造对象的方法,这对我的用户来说非常危险,我想避免这种情况。假设我有自己的整数类,我想传递一个可选的此类整数并将其存储在某个类中:classmyint{public:intm_a;myint(intr_a):m_a(r_a){}};structmyclass{boost::optionalcontent;myclass(constboost::optional&arg):content(arg){}};现在,用户将如何使用该类:myclass(myint(13));//correctusemyclass(boost::none);//