草庐IT

cc-option

全部标签

没有 .cc 文件的 .o 文件的 C++ 编译

我有一个程序,我得到了编译后的.o文件,但我没有原始的.cc文件,而且我只有一个半成品的头文件。头文件具有所有方法签名,但缺少私有(private)变量声明。我试图让这个.o文件与项目一起工作,但在.o文件定义的类的构造函数中出现段错误。程序编译。我如何让它工作?该程序是家庭作业,老师不希望我们看到.cc文件。我的老师也知道这个问题。我只是想自己弄清楚(并希望在你们的帮助下:))。我以为我之前和另一位老师做过这个,但没有任何问题。有一个用于编译程序的makefile。 最佳答案 如果您使用的是C++程序,并且头文件包含类定义,则类定

c++ - 谷歌测试 Gtest.cc :812: error: 'gettimeofday' was not declared in this scope

我正在尝试通过命令行通过MinGW编译Google测试,但是当我尝试使用命令进行编译时gcc-ID:\gtest-ID:\gtest\include-ID:\gtest\include\gtestsrc\gtest_main.ccsrc\gtest-all.cc它抛出错误Gtest.cc:812:错误:'gettimeofday'未在此范围内声明我通过VisualStudio成功编译,所以我猜这不是代码的错误。还有其他人遇到过这个问题并且知道解决方案吗? 最佳答案 and是两个不同的包含

c++ - 正则表达式 ("(abc|aa.*|bb.*)") 与正则表达式 ("(aa.*|bb.*|cc.*)");

这个问题在这里已经有了答案:Isgcc4.8orearlierbuggyaboutregularexpressions?(3个答案)关闭8年前。我在c++11(ubuntu14.4,gcc4.8.2)中使用正则表达式时遇到一个奇怪的问题#include#includeusingnamespacestd;intmain(){regexr("(abc|aa.*|bb.*)");cout同时intmain(){regexr("(aa.*|bb.*|cc.*)");cout我想知道为什么“bb11”得到不同的结果?

c++ - boost program_options 开/关标志

使用bool_switch,我可以写一个命令行选项来打开一个标志:boolflag;po::options_descriptionoptions;options.add_options()("on",po::bool_switch(&flag)->default_value(false));现在./a.out将有flag==false而./a.out--on将有标志==真。但是,为了明确起见,我还想添加一个命令行选项来关闭标记。像这样的东西:options.add_options()("on",po::bool_switch(&flag)->default_value(false))(

c++ - 为 boost::program_options 设置精度

有没有办法改变boost::program_options在program_options::options_description的帮助文本中格式化选项的默认值的方式?(那个可以通过cout得到)?特别是我有默认值是float,所以通常的十进制到二进制转换给我一个看起来像--arg(0.100000001)的帮助文本。这是非常丑陋的。使用cout不起作用,因为program_options是将自身设置为某些内部流的默认值以首先进行格式化(至少这是我通过查看源代码推断的),然后得到的结果。编到cout是结果字符串(流?)。谢谢。 最佳答案

c++ - CMake add_compile_options 在适当的时候会影响链接器选项吗?

一些编译器选项实际上可能需要额外的链接选项才能真正有效。例如,启用GCC'sLinkTimeOptimization,-flto选项必须在编译命令和链接命令中传递。有一个漂亮的builtincmakecommand用于添加编译选项,但据我所知,没有相应的链接选项命令。即使有,当我使用的编译选项暗示它们时需要明确指定它们也会很烦人。那么add_compile_options(-flto)是否将-flto添加到link命令?如果没有,我是否需要直接设置(LINK_FLAGS....? 最佳答案 add_compile_options和t

c++ - 在 boost::program_options 解析我的命令行参数后,如何获取非标志和非选项标记

在python中,我可以构建我的optparse实例这样它会自动将选项和非选项/标志过滤到两个不同的桶中:(options,args)=parser.parse_args()使用boost::program_options,我如何检索token列表,这些token是剩余的非选项和非标志token?例如如果我的程序有标志--foo--barBAR然后我传入命令行:--foohey--barBARyou我怎样才能得到一个仅由标记“嘿”和“你”组成的列表 最佳答案 这是一个例子:namespacepo=boost::program_opt

c++ - boost::program_options:如何获取应用程序名称?

使用BoostProgramOptions,如何获得argv[0]的字符串等价物? 最佳答案 我认为这是不可能的。这可能是因为程序名称也可以合法地用作选项名称。命令行解析器代码明确跳过相关的argv成员:templatebasic_command_line_parser::basic_command_line_parser(intargc,charT*argv[]):detail::cmdline(//Explicittemplateargumentsarerequiredbygcc3.3.1//(atleastmingwversi

c++/boost program_options 一个选项禁用其他

我有这样的代码:namespacepo=boost::program_options;po::options_descriptiondesc("Allowedoptions");desc.add_options()("help","producehelpmessage")("mode1","")("mode2","");po::variables_mapvar_map;po::store(po::parse_command_line(argc,argv,desc),var_map);po::notify(var_map);我的程序只能在模式1或模式2下运行。我不想要这样的语法--mod

c++ - 使用 boost::program_options 禁止无符号值的负参数

假设我有一个程序使用boost::program_options来解析命令行参数,其中一个有一个unsigned值:#include#includenamespacepo=boost::program_options;intmain(intargc,char*argv[]){unsignednum;po::options_descriptiondesc;desc.add_options()("num,n",po::value(&num),"Non-negativenumber");po::variables_mapvm;po::store(po::parse_command_line(