草庐IT

c++ - gdb 7.5.1 调试通过 g 4.7.2 构建的可执行文件的问题

我一直在更新我的Mac工具链,以便利用C++11功能并最终获得STL数据结构的pretty-print调试。我使用Homebrew构建了gcc4.7.2编译器。我已经能够使用这个新的编译器重新编译我当前项目的源代码。然而,我尝试过的所有版本的gdb在设置断点、查看源代码或查看局部变量时都会出现各种问题。我认为作为Xcode命令行工具的一部分安装的gdb版本6.3.50无法显示各种基于模板的变量。我还构建并尝试使用其他几个gdb版本(7.3.1、7.4.1和7.5.1),但每个gdb版本都有问题,导致很难甚至无法设置断点、查看源代码和查看变量。具体来说,这些gdb版本不知道头文件中定义的

c++ - Intel (windows) c++ 编译器并将其库实现更改为 gcc。可能吗?

不确定这是不是该问的地方,但这里是来自page在英特尔网站上,它指出:TheIntelC++CompilerforWindowsusestheMicrosoftVisualC++headerfiles,librariesandlinker.Microsoftcontrolstheheaderfilesthatdefinethenamespace.ContactMicrosoft'stechnicalsupportinreferencetoMicrosoft'sconformancetotheC++standardonthisissue...link是否有英特尔(或其他)指南将库从vis

c++ - 带有自定义消息的基于模板的编译时断言只能在某些编译器中编译

此代码演示了使用模板的编译时断言。我发现它只能由g++(4.4.7)使用以下cmd行编译。$g++-std=c++98a.cpp-oaNethericc(13.0.1)和visualc++(14.00.50727.762for80x86)都不能编译它。对于icc,它会像这样生成错误消息$icpca.cpp-oaa.cpp(13):error:non-integraloperationnotallowedinnontypetemplateargumentCOMPILE_TIME_ASSERT(true&&"errmsg");^a.cpp(13):error:class"CompileTi

c++ - 如何忽略 [默认启用] 的特定 gcc 警告?

我有以下程序将绿色文本打印到终端:#include#include//returnsacoloredstringforterminaloutputstreamsstd::stringcolorize_forground(std::stringconst&message,intconst&background){returnstd::string("\e[38;5;"+std::to_string(background)+"m"+message+"\x1b[0m");}intmain(){std::cout但是,当我用下面的警告标志编译程序时,g++-std=c++1y-pedantic

c++ - gcc 4.8 或更早版本是否存在关于正则表达式的问题?

我正在尝试在一段C++11代码中使用std::regex,但该支持似乎有点问题。一个例子:#include#includeintmain(intargc,constchar*argv[]){std::regexr("st|mt|tr");std::cerr输出:st|mt|trmatchesst?1st|mt|trmatchesmt?1st|mt|trmatchestr?0当使用gcc(MacPortsgcc474.7.1_2)4.7.1编译时,要么使用g++*.cc-otest-std=c++11g++*.cc-otest-std=c++0x或g++*.cc-otest-std=gn

c++ - 默认模板类参数混淆了 g++?

昨天我遇到了一个g++(3.4.6)编译器问题,我使用Intel(9.0)编译器编译的代码没有问题。这是显示所发生情况的代码片段:templateclassFoo{};structBar{voidmethod(Fooconst&stuff=Foo());};g++编译器错误是:foo.cpp:5:error:expected`,'or`...'before'>'tokenfoo.cpp:5:error:wrongnumberoftemplatearguments(1,shouldbe2)foo.cpp:2:error:providedfor`templatestructFoo'foo.

c++ - QObject 实例池

我遇到了一个问题,我不确定如何解决..我们有通用对象池。当请求对象时,池将QSharedPointer返回给第一个可用的实例,并指定自定义删除器。当QSharedPointer实例引用计数为0时,删除器仅将对象返回到池中。对于普通对象,一切都很好。当在Qt5中编译时,它也适用于QObject后继者。但是,如果在Qt4.6中编译-问题开始:当第二次请求相同的对象时-应用程序退出并出现错误:"QSharedPointer:pointerxxxalreadyhasreferencecounting"我写了简单的测试:QObject*obj=newQObject();QSharedPointe

c++ - 如何将 GCC 的 printf 格式属性与 C++11 可变参数模板一起使用?

我有一个C++类,它是日志系统的前端。它的日志记录功能是使用C++11的可变参数模板实现的:templatevoidFrontend::log(constchar*fmt,Args&&...args){backend->true_log(fmt,std::forward(args)...);}每个日志记录后端都实现了自己的true_log版本,除其他外,它使用转发的参数调用vsnprintf。例如:voidBackend::true_log(constchar*fmt,...){//otherstuff..va_listap;va_start(ap,fmt);vsnprintf(buf

c++ - 非命名空间范围内的显式特化

这个问题在这里已经有了答案:C++syntaxforexplicitspecializationofatemplatefunctioninatemplateclass?(9个回答)关闭8年前。templateclassCConstraint{public:CConstraint(){}virtual~CConstraint(){}templatevoidVerify(intposition,intconstraints[]){}templatevoidVerify(int,int[]){}};在g++下编译会出现以下错误:Explicitspecializationinnon-name

c++ - 为什么我可以在 C++ 中定义这个可变长度数组?

这个问题在这里已经有了答案:Arrayofsizedefinedbynotconstantvariable(3个答案)关闭8年前。给定gcc-cmain.Cgcc-lstdc++-omainmain.o而main.C是#includeintmain(){intsomany;std::cin>>somany;doubleex[somany];for(inti=0;i为什么这不会导致编译器错误?我以为C++没有VLA?执行程序工作正常。