草庐IT

compiler-options

全部标签

c++ - 为什么library API + compiler ABI就足以保证不同版本gcc对象之间的兼容性?

我遇到过这样一种情况,我可能想将使用一个版本的gcc编译的C++共享对象库与一些将使用另一个版本的gcc编译的代码一起使用。特别是,我想使用返回一些STL容器的方法,例如std::string和std::map。gccwebsite许多旧的stackoverflow帖子(例如here)讨论了这个问题。我目前的理解是关于此问题的大部分关注和帖子都是关于.so文件和.dll文件之间的交叉兼容性。由于不同的编译器ABI,这非常困难。对于使用不同版本的gcc(至少gcc版本>=3.4)编译的.so文件之间的交叉兼容性,您需要确保标准库API没有改变(并且,如果它有,有dualABI支持)。我的

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

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

C++14 元编程 : Automagically build a list of types at compile/init time

使用C++14和CuriouslyRecurringTemplatePattern(CRTP)以及可能的Boost.Hana的某种组合(或boost::mpl如果您愿意),我可以在编译时(或静态初始化时)构建一个类型列表而无需显式声明吗?例如,我有这样的东西(在Coliru上查看):#include#include#includenamespace{structD1{staticconstexprautoval=10;};structD2{staticconstexprautoval=20;};structD3{staticconstexprautoval=30;};}intmain(

java - OOP 访问修饰符 : Compile-time or Run-time

我听说访问修饰符Public、Private和Protected只是一些编译器的东西,它们实际上并不存在于编译的二进制代码中.现在我想知道它有多少是正确的?如果它是正确的,是否意味着封装在运行时不存在于二进制代码中?因此,如果您修改二进制文件以非法访问Private方法,理论上,没有任何东西可以检查您的权限,无论是任何OOP机制还是操作系统,对吧?我还标记了C++和Java的问题。我知道它们之间的区别,只是想看看它们处理访问修饰符有何不同。 最佳答案 访问修饰符只是C++中的一种编译时机制。然而,在Java中,它们也在运行时强制执行

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

c++ - 在 Boost::Program_Options 中,如何设置 wstring 的默认值?

我的下面的代码没有工作:wstringconfig_file;//Declareagroupofoptionsthatwillbe//allowedonlyoncommandlinepo::options_descriptiongeneric("Genericoptions");generic.add_options()("help,h","producehelpmessage")("config,c",po::wvalue(&config_file)->default_value(L"DXDrv.cfg"),"nameofafileofaconfiguration.");编译失败,错

c# - 谁知道mc.exe(Message Compiler)怎么用?

我正在尝试使用mc.exe为我的事件日志编写程序制作消息文件。但即使是samplemessagefile微软提供的不会编译。谁知道mc.exe可以编译的消息文件怎么写?编辑:我收到的错误信息是:msgs.mc(1):error:expectedkeyword-??编辑2:问题已解决。mc.exe只能支持Unicode或ANSI编码的源文件。我的文件编码为UTF8。就是这样。谢谢。 最佳答案 始终记录您收到的错误消息被迫猜测:如果您在第82行遇到错误,提示无效字符(0x2e),则在文本编辑器中打开文件,将光标放在.然后按Enter以换

解决:xxx has been compiled by a more recent version of the Java Runtime (class file version 55.0)

原因当前类是由jdk1.8版本编译,当前运行环境低于jdk1.8,故出现当前情况。javacode和name对应关系49=Java550=Java651=Java752=Java853=Java954=Java1055=Java1156=Java1257=Java1358=Java14解决方案升级当前项目jdk版本号,或者降低引用库编译的jdk版本号android{ ...compileOptions{sourceCompatibilityJavaVersion.VERSION_1_8targetCompatibilityJavaVersion.VERSION_1_8}}

c++ - "most important const"与 auto_ptr : Why the code does not compile?

以下代码无法在VisualC++2008或2010上编译:#includestructA{};std::auto_ptrfoo(){returnstd::auto_ptr(newA);}conststd::auto_ptrbar(){returnstd::auto_ptr(newA);}intmain(){conststd::auto_ptr&a=foo();//mostimportantconstconststd::auto_ptr&b=bar();//errorC2558://class'std::auto_ptr'://nocopyconstructoravailableorco