草庐IT

gcc-plugin

全部标签

c++ - 是否可以在 gcc 3.3+ 中以旧方式使用 __func__? (C++)

对于3.3之前的gcc版本和MS编译器,我使用以下宏:DEBUG_WARNING(...)printf(">WARNING:"__FUNCTION__"()"__VA_ARGS__);使用:DEBUG_WARNING("someFunctionreturned%d",ret);输出:>WARNING:Class::FunctionName()someFunctionreturned-1当我们有很多系统时,它非常方便,所有系统都发送输出。它是一个单行宏,允许我们相应地过滤输出。小代码,大用途,快乐我。由于__FUNCTION__(和C++中的__func__)定义发生了变化(我相信是为了

c++ - 我可以让 gcc 链接器创建一个静态库吗?

我有一个包含大约300个c++文件的库。使用库的程序不想动态链接到它。(由于各种原因,但最好的一个是某些支持的平台不支持动态链接)然后我使用g++和ar创建一个静态库(.a),这个文件包含所有这些文件的所有符号,包括库不想导出的符号。我怀疑将消耗程序与该库链接会花费不必要的长时间,因为.a中的所有.o文件仍然需要解析它们的引用,并且链接器有更多符号要处理。创建动态库(.dylib/.so)时,您实际上可以使用链接器,它可以解析所有库内符号,并仅导出库想要导出的那些。然而,结果只能在运行时“链接”到使用程序中。我想以某种方式获得动态链接的好处,但使用静态库。如果我的谷歌搜索是正确的,认为

c++ - Visual Studio 还是 GCC?

按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visitthehelpcenter指导。关闭10年前。学习cpp编程应该选择什么?据我所知,两者都支持语言,但如果我必须做出选择,这真的有什么不同吗?

c++ - 在 gcc 中使用关键字

我得到了两个包含相同变量名称('aa')的结构('AAA'和'BBB'),以及通过多重继承使用两者定义的第三个结构('CCC')。[这两个结构应该是无关的,所以当两个类有一个共同的祖先时,这不是著名的菱形问题]。对于派生结构“CCC”,我试图明确选择在派生结构“AAA”中使用var,但gcc仍然提示模棱两可的def。为什么?structAAA{intaa;};structBBB{intaa;};structCCC:publicAAA,publicBBB{usingAAA::aa;};intmain(){CCCccc;returnccc.aa;}给出:x.cpp:Infunction'i

c++ - yyparse() 未在 Bison/Flex C++ 项目中仅针对某些版本的 gcc/bison/flex 声明

首先,我对Bison和Flex还很陌生。我知道这些工具是为在C中使用而设计的,我感觉我所有的问题都来自于在C++中使用它们。我不确定我是否以正确的方式完成了它。该代码在我的计算机上编译正常,但在我的大学服务器上编译不正常。我已将问题隔离到此处发布。在我的大学:$(g++--version;bison--version;flex--version)|grep'[0-9]\.'g++(Debian4.4.5-8)4.4.5bison(GNUBison)2.4.1flex2.5.35Athome:HOME$(g++--version;bison--version;flex--version)

c++ - 从 GCC 得到 "no matching function"

为什么这个简单的代码不起作用?templateclassretype{typedefUtype;};classobject{public:templateintcreate(typenameretype::typep){return4;}};intmain(){intn=object().create(5);return0;}使用GCC编译时出现此错误:test.cpp:Infunction‘intmain()’:test.cpp:20:error:nomatchingfunctionforcallto‘object::create(int)’问题出在哪里?

c++ - 为什么 GCC 给我一个错误 : no unique final overrider?

在下面的代码中,我收到以下警告和错误:test.cpp:15:warning:directbase'B'inaccessiblein'D'duetoambiguitytest.cpp:15:error:nouniquefinaloverriderfor'virtualvoidA::f()'in'D'但是如果我从A中移除B的虚拟继承(即structB:publicA),我只会得到警告,没有错误。structA{virtualvoidf()=0;};structB:publicvirtualA{voidf(){}};classC:publicB{};structD:publicC,virt

c++ - 如果我在 GCC 中编译和链接不需要的库会怎样?

我想这个标题有点令人困惑,但我会尽力澄清我的意思。下面我附上了我的制作文件。正如您在第四行看到的,我正在选择我希望我的项目链接到的所有库。当项目编译时,我看到它正在创建的每个目标文件都与LIBRA行指定的所有库链接。并非我项目中的所有文件都需要所有这些库。每个.cpp文件中可能只有一两次使用。这是否会在编译过程中产生任何额外成本?这会创建更大的二进制文件吗?现代编译器是否足够好以至于这不是问题,还是我必须阅读更多关于编译器的文献?CC=g++CFLAGS=-c-Wall-std=c++11-gLDFLAGS+=-ldlLIBRA=-lboost_system-lboost_filesy

c++ - 警告 : 'visibility' attribute ignored - symbol visibility - C++/gcc

相关主题:Whydoesconstimplyinternallinkageinc++,whenitdoesn'tinC?我正在关注GCCvisibilitywiki为我的共享库添加可见性。当我编译我的源文件时它会生成一个警告warning:'visibility'attributeignored[-Wattributes]这是我的代码://my_shared_lib.h#if__GNUC__>=4#defineDLL_API__attribute__((visibility("default")))#defineDLL_LOCAL__attribute__((visibility("h

c++ - 与 GCC/MSVC 中的 lambda 转换构造函数不一致

哪个(如果不是两个)违反规范?在MSVC2013和MSVCNov2013CTP上尝试使用MSVC,GCC是MinGWx644.9.1with-std=c++11。templateclassmemoizer{usingfunc_type=ret_type(*)(constint);constfunc_typefunc;std::mapcache;public:memoizer(func_typefunc):func(func){}ret_typeoperator[](constintn){constautoit=cache.find(n);if(it!=cache.end())retur