草庐IT

opt_options

全部标签

c++ - Boost Program_Options 抛出 "character conversion failed"

我在Ubuntu14.04上,使用CMake和CLion。我正在尝试使用程序选项,以下代码取自其文档中的示例:#include#includeintmain(intac,char*av[]){namespacepo=boost::program_options;usingnamespacestd;po::options_descriptiondesc("Allowedoptions");desc.add_options()("help","producehelpmessage")("compression",po::value(),"setcompressionlevel");po::

c++ - 如何为 boost::program_options 的位置选项添加描述?

我想用boost_program_options创建一个位置列表程序选项,不允许命名程序选项(如--files)。我有以下代码片段:#include#include#include#includenamespacepo=boost::program_options;intmain(intargc,constchar*argv[]){po::options_descriptiondesc("Allowedoptions");desc.add_options()("help","producehelpmessage")("files",po::value>()->required(),"l

c++ - 使用带有 std::optional 参数的 std::function 重载歧义

这是一个简单的示例程序:usingfn_string=function;usingfn_optional_string=function&)>;voidfoo(fn_string){cout&){});//它有2个重载foo()--一个使用string的函数参数和另一个optional.为什么第二次调用foo()模棱两可?有没有简单的方法来修复它?没有Actor?更新以上是我试图解决的以下现实世界问题的过度简化示例,即:usingdelegate=variant,function,function&)>>;structfoo{voidadd_delegate(delegatefn){f

c++ - 在模块化程序中使用 Boost.Program_options

我使用的代码由一组模块组成,编译成单独的库。反过来,库以不同的组合链接以构建不同的二进制文件。所以,这是非常有序的。不同的模块使用不同的命令行参数,我想使用Boost.Program_options进行解析。由于命令行参数集取决于链接在一起的库,我事先不知道所有参数,因此无法将它们添加到program_options::options_description。如何使每个模块能够添加其命令行参数并稍后读取它们?谢谢 最佳答案 例如通过使用options_description的成员函数add(constoptions_descript

Optional类的使用指南:解决空指针异常

在Java应用程序中,空指针异常是导致程序失败的最常见原因之一。为了更加优雅地处理空指针异常,Java8引入了Optional类库。Optional实际上是一个容器,可以保存类型T的值,或者仅仅保存null。通过使用Optional,我们能够避免显式进行空值检测,使代码更加清晰和健壮。1.Optional类是什么?Optional类(java.util.Optional)是一个容器类,它可以保存类型T的值,代表这个值存在。或者仅仅保存null,表示这个值不存在。原来用null表示一个值不存在,现在Optional可以更好的表达这个概念。并且可以避免空指针异常。Optional提供很多有用的方法

c++ - 链接到 boost::program_options 不能正常工作

存在以下库文件:cls/usr/local/Cellar/boost/1.51.0/lib$lslibboost_program*libboost_program_options-mt.alibboost_program_options-mt.dylib我在#include中包含以下标题:cls/usr/local/Cellar/boost/1.51.0/include$lsboost/program_options.hppboost/program_options.hpp我尝试将库链接到-lboost_program_options-mt-L/usr/local/Cellar/boo

c++ - boost::optional 不允许我重新分配 const 值类型

在我看来应该有四个变体boost::optionaloptional=>持有一个可变的Foo并且可以在初始化后重新分配optionalconst=>持有一个constFoo并且不能在初始化后重新分配optionalconst=>(应该?)持有一个可变的Foo但不能在初始化后重新分配optional=>(应该?)持有一个constFoo并且可以在初始化后重新分配前2个案例按预期工作。但是optionalconst取消对constFoo的引用,以及optional不允许在初始化后重新分配(如thisquestion中所述)。const值类型的重新分配是我遇到的具体问题,错误是:/usr/i

c++ - Boost Program_options 配置文件注释

我有一个程序使用boost::program_options从配置文件中读取大量变量。配置文件正在运行并读取值,但是由于文件中有很多选项,我想将它们记录在案。例如我希望配置文件看起来像:#Hereisadescriptionofflag1#flag1=truemeansblahblahblah#flag1=falsemeans...flag1=true#Hereisadescriptionofflag2...问题是我在任何地方都找不到描述执行此操作的方法的文档。我相当确定我可以使用诸如a=之类的东西对于我的评论分隔符,只需将所有评论分配给std::vector解析后被丢弃,但是我想知道

c++ - 如何在 C++ 中使用 std::optional

在C++17中引入了std::optional,我很高兴这个决定,直到我看到ref.我从Scala、Haskell和Java8知道Optional/Maybe,其中optional是一个monad并遵循monadic法则。C++17实现中不是这种情况。我应该如何使用std::optional,没有像map和flatMap/bind这样的函数,那是什么使用std::optional与例如返回-1或函数计算结果失败时的nullptr相比有优势吗?对我来说更重要的是,为什么std::optional没有设计成monad,有什么原因吗? 最佳答案

c++ - Protocol Buffer : how nested (custom) optional fields are to be handled in C++?

读入ProtocolBufferBasics:C++,没有找到符合情况的东西:;以下.proto处理--cpp_out,messageA{requiredint32foo=1;}messageB{optionalAdata=1;}没有生成明显的访问器/setter来设置自定义可选字段(包括我懒得放在这里的“嵌套类型”部分)://accessors-------------------------------------------------------//optional.A=1;inlineboolhas_a()const;inlinevoidclear_a();staticcon