草庐IT

gcc-plugin

全部标签

c++ - gcc 报告基于版本的库的未引用符号

我的一个共享库my.so使用基于版本的符号作为库test.so中的符号@@test_1.2.3。当我将my.so共享库与我的可执行文件链接时,它显示“未引用的符号符号@@test_1.2.3”。当链接行如下时会发生这种情况-g++-omyexecutablemyexecutable.o-L/path-to-my.so-lmy-L/path-to-test.so-ltest如果我将链接链接更改为-g++-omyexecutablemyexecutable.o-L/path-to-my.so-lmy/path-to-test.so/libtest.so它有效。为什么libtest.so在使

c++ - 为什么在 gcc 库中重复声明相同的类型

在gcc库中,模板basic_stringbuf是从basic_streambuf派生而来的。在基类basic_streambuf中,已经声明了char_type、traits_type等类型名称。为什么它们在子类basic_stringbuf中重复声明?相关代码贴在下面//c++/4.2.1/streambuftemplateclassbasic_streambuf{public://@{/***Thesearestandardtypes.Theypermitastandardizedwayof*referringtonamesof(ornamesdependanton)thetem

c++ - 一个 gcc 编译错误(关于复制 c'tors)这看起来很奇怪(至少对我来说)

因此,我有以下代码无法在OSX上的gcc4.2.1上编译。我得到的错误是:testref.cpp:Infunction‘intmain()’:testref.cpp:10:error:‘A::A(constA&)’isprivatetestref.cpp:20:error:withinthiscontext这是代码#includeclassA{public:A(){i=0;printf("Actor\n");}~A(){printf("Adtor\n");}private:A(constA&other){i=other.i;printf("ACOPYCTOR\n");}A&operat

c++ - GCC - 'sizeof' 之前的预期不合格 ID - Android NDK 中的 IT++ 4.2

我已成功在我的AndroidNDK项目中构建CLAPACK。接下来,我尝试将IT++4.2库放入其中。但是,我有一些无法修复的错误。这些是我在我的项目中所做的事情:首先,我将itpp文件夹复制到我项目的jni文件夹中,并修改了itpp中的config.h。因为我在(放在..android-ndk-r7b\platforms\android-9\arch-arm\usr\include中)找到了isfinite、isinf和isnan函数。我将HAVE_DECL_ISINF、HAVE_DECL_ISFINITE和HAVE_DECL_ISNAN设置为1。config.h#ifndefCON

c++ - gcc 的 boost::variant 链接器错误

我有点发疯了,想弄清楚为什么以下代码无法编译:#include#include#include#includetypedefunsignedlonglongvery_long;typedefboost::variantvariants_type;typedefstd::arrayrow_type;typedefstd::forward_listrows_holder_type;intmain(){rows_holder_typerows;row_typerow_data;row_data[0]=0;row_data[1]=0;row_data[2]=0;row_data[3]=0;ro

c++ - 使用 GCC 4.6.2 C++ Qt、MinGW、Vista 设置堆栈大小

我想增加我的程序的堆栈大小,因为我有一个复杂的递归算法,迭代重写将是一个真正的痛苦。我正在使用GCCC++4.6.2。MinGw,在Vista上使用Qt.pro文件构建(我使用Qt作为GUI前端)。本网站的建议是使用:-gcc-Wl,--stack,4194304并将其发送到g++链接阶段:-LIB+=-Wl,--stack,4194304但是链接器错误:-g++:error:unrecognizedoption'--stack,4194304'我尝试使用QMAKE_CXXFLAGS+=将选项发送到编译阶段,但g++仍然barfs。唯一不会barf的选项是GCC文档(.pdf4.5.0

c++ - gcc 4.7 和递归 constexpr 函数

我正在玩constexpr递归并尝试查看它是如何编译的,我不明白在什么情况下gcc选择在编译时或运行时计算递归。我正在使用以下阶乘计算代码:#includeconstexprunsignedintfactorial(unsignedinti){returni>0?i*factorial(i-1):1;}intmain(void){std::cout然后我更改值x在阶乘中。在没有优化的情况下编译时,表达式不会在编译时计算。使用-O1编译时标志,表达式在编译时仍未计算。与-O2,如果x,表达式是在编译时计算的.在这个值之后,阶乘被内联实现为一个循环。更改-fconstexpr-depth的

c++ - 'long long long' 对于使用 log4cpp 的 GCC 来说太长了

我正在开发一个使用日志库log4cpp的QT应用程序。但是现在,在包含log4pp的头文件的地方,我得到了这个编译错误:'longlonglong'对于GCC来说太长了当我找到这个错误的根源时,头文件stdint.h在这一行打开:__MINGW_EXTENSIONtypedeflonglongint64_t;有人能告诉我如何处理吗? 最佳答案 好的,解决了,我只需要在开始时包含stdint.h 关于c++-'longlonglong'对于使用log4cpp的GCC来说太长了,我们在Sta

c++ - Linux gcc 和 Windows Visual Studio 处理静态常量的区别?

我们一直在Linux(gcc)和Windows(VisualStudio)上编译一个库,正如预期的那样,发现在两个平台上获得干净编译所需的东西之间存在细微但不显着的差异。今天,我将gcc编译器标志更改为使用-fPIC(以启用共享库)。当我们测试将程序链接到库时,我们开始出现错误(第一次),undefinedreference指向2个在头文件中声明和初始化的静态常量(但不在.cpp中文件)。我找到了thisStackOverflowanswer这似乎解决了这个问题,解释说,即使staticconst在头文件中初始化,它仍然需要在代码文件中定义。进行该更改确实消除了gcc链接器错误。但是,

c++ - 禁用关于 "underscore-prefixed user-defined literals"的 GCC 警告

我的一个客户有很多代码使用了“ui64”、“ui32”等...后缀,我需要移植它。为了避免验证几个正则表达式查找+替换的可能漫长的夜晚,我将所述后缀重现为用户定义的文字。我正在寻找“-Wno-xxx”标志,用于作为结果弹出的“前面没有‘_’”警告。我搜索了警告列表here,但我的大脑目前正遭受相当严重的字母汤综合症,所以我可能错过了。我使用的是cygwin附带的g++4.8.2。 最佳答案 我相信您正在寻找-Wno-literal-suffix。从gcc-7开始(见此处liveongodbold),这个选项也是turnsoffwar