草庐IT

c++ - 与 C++ 库链接时,如何在 OCaml 编译中抑制 g++ 弃用警告?

当编译一个链接到需要C++标准库(例如LLVM的OCaml绑定(bind))的库的OCaml项目时,使用-ccg++参数到ocamlc和GCC>=4.4生成形式极其冗长的警告:warning:deprecatedconversionfromstringconstantto‘char*’如何删除这些警告? 最佳答案 问题源于ocamlc生成中间C代码,当较新版本的GCC在C++模式下编译时会触发警告。但是这个生成的代码不需要编译为C++。对于针对包装的C++库构建的这种常见情况,通过-ccg++的唯一原因是确保构建C++标准库依赖项。

c++ - std::regex 等效于 '/g' 全局修饰符

在Perl中,我可以这样做:$text='1747239';@matches=($text=~m/(\d)/g);#@matchesnowcontains('1','7','4','7','2','3','9')使用C++正则表达式匹配,复制此行为的最佳方法是什么我得到一个包含所有匹配项的匹配集?我现在有这个:-compiledRegex=std::regex(regex,std::tr1::regex_constants::extended);regex_search(text,results,compiledRegex);intcount=results.size();//Allo

c++ - c++11 模式下奇怪的 g++ 预处理器行为

我遇到的问题是,当g++在c++11模式下运行时,一些处理器宏没有正确展开。这让我在使用Qt编译程序时遇到麻烦。$g++--versiong++(GCC)4.7.2Copyright(C)2012FreeSoftwareFoundation,Inc.Thisisfreesoftware;seethesourceforcopyingconditions.ThereisNOwarranty;notevenforMERCHANTABILITYorFITNESSFORAPARTICULARPURPOSE.以下片段暴露了问题:$catfoo.cpp//#include#defineQTOSTRI

c++ - G++ 新的 ABI 问题

我在GCC中为C++11引入的新ABI遇到了问题。升级到GCC5.3后,我的项目不再编译。我收到的错误消息很简单:undefinedreferenceto`tokenize(std::__cxx11::basic_string'...morecharacters或undefinedreferenceto`extract(std::stringconst&)'所以,看起来我搞砸了,GCC无法决定我是想要旧ABI还是新ABI(__cxx11::部分在某些错误消息中丢失,并且存在在其他)?我尝试了几种解决方案来解决这个问题:将-D_GLIBCXX_USE_CXX11_ABI=0传递给GCC,

c++ - -static-libstdc++ 适用于 g++ 但不适用于纯 gcc?

作为引用,我使用的是MinGW(GCC5.3)。使用编译文件时g++file.cc-static-libstdc++它静态链接C++标准库(libstdc++)并生成1.9MB的可执行文件。无论如何运行gcc-lstdc++-static-libstdc++file.cc它仍然动态链接到libstdc++-6.dll并生成一个34KB的可执行文件。为什么-static-libstdc++仅适用于g++而不适用于纯gcc? 最佳答案 GCCmanual,LinkOptions说:-static-libstdc++Whentheg++p

c++ - g++模板问题

我正在将我的C++Windows代码(msvc和英特尔)移植到Linux(g++)。该代码使用了大量模板(我喜欢元编程;-)。但是我无法编译这段代码:templatestructA{templatestructB;};templatestructC{};templatestructD{templateclassT{};};templatetemplatestructA::B:C::T>{intfoo;};g++告诉我在A::B的定义中,C类具有无效的模板参数。但是在msvc和intel上它运行良好!这里有什么问题?PS:对不起,我不能发布原始代码,因为它的模板太复杂了。但是这个例子实际

c++ - 通过引用 const char* 传递字符串文字无法使用 g++ 4.6.3 进行编译

这是来自C++Primer,第4版,第16章的示例,它是关于模板特化的。templateintcompare(constT&v1,constT&v2){if(v1intcompare(constchar*const&v1,constchar*const&v2){returnstrcmp(v1,v2);}intmain(intargc,constchar*argv[]){cout我预计compare("abc","defg")将调用模板的专用版本。但事实是,g++4.6.3不会编译此代码并给出以下错误:error:nomatchingfunctionforcallto'compare(c

c++ - 为什么用 Visual Studio 2013 而不是 g++-4.8.1 编译?

以下示例(ideone)在Windows7上使用VisualStudio2013时编译并工作,但在Ubuntu13.10上使用g++4.8.1时则不能。#include#include#include#include#include#include//Wrapsastd::arrayofTKey/TValuepairsandprovidesamethod//torandomlyselectaTKeywithTValuebias.templateclassweightsfinal{public:usingpair=conststd::pair;usingarray=conststd::a

c++ - 我怎样才能用 GNU g++ 只编译标准 C++?

GNUg++编译器中有一些扩展,例如VLA(可变长度数组),即使这些功能不是C++标准。因此,如果我需要仅使用C++标准构造来编译程序并避免那些额外的扩展,我可以使用GNUg++来完成吗?像g++test.cpp-std=onlyStandards这样的东西? 最佳答案 传递-pedantic-errors标志。请务必使用-std=设置标准,例如-std=c++14。这也适用于clang。 关于c++-我怎样才能用GNUg++只编译标准C++?,我们在StackOverflow上找到一个

c++ - clang 和 g++ 在处理 const 对象时的差异

这个问题在这里已经有了答案:Whydoesgccallowaconstobjectwithoutauser-declareddefaultconstructorbutnotclang?(1个回答)关闭8年前。考虑代码:structFoo{intx=10;};intmain(){constFoofoo;}它在g++下编译http://coliru.stacked-crooked.com/a/99bd8006e10b47ef,但是在clang++http://coliru.stacked-crooked.com/a/93f94f7d9625b579下会报错:error:defaultini