草庐IT

c++ - clang 和 gcc 中的这个警告似乎不正确

我相信BjarneStroutrup的新书TCPL第4版第66页中的示例有一个小错误,因为classVector_container没有std::initializer_list构造函数。错误信息here证实了这一点。#includeclassVector{double*elem;intsz;public:Vector(ints):elem{newdouble[s]},sz{s}{for(inti=0;i!=sz;++i)elem[i]=0;}Vector(std::initializer_listlst):elem{newdouble[lst.size()]},sz(lst.size

c++ - g++ : Using singleton in an embedded application

我正在使用C++中的GNUARM工具链使用GCC4.8为CortexM3开发嵌入式应用程序。该应用程序使用了一些通过函数局部静态变量实例化的单例,就像这样(真实代码):GlobalDataTypeRegistry&GlobalDataTypeRegistry::instance(){staticGlobalDataTypeRegistryinst;returninst;}这是在C++中实现单例的经典方法。问题是一旦我使用这种实例化,输出代码大小就会激增,这显然意味着编译器/链接器添加了一些服务代码以正确初始化/销毁单例对象。这是允许重现问题的最小示例:这将编译成66k代码(-Os):s

c++ - 如何允许用户重新配置编译器以与 cmake 一起使用?

我想让用户运行一个cmake配置工具(例如ccmake或cmake-gui)来更改使用的编译器。这是必要的,因为我正在构建一个有时在集群上运行的跨平台程序(因此需要具有适当MPI构造的特定于集群的编译器)但有时在非MPI模式下运行。让我们假设编译器通常可以是平台期望的任何编译器(通常是gcc/g++或在最坏的情况下是MSVC),但是当我们使用MPI时,我们总是知道我们需要通过mpicc/mpicxx进行编译。我觉得下面的代码应该可以工作:cmake_minimum_required(VERSION2.4)option(USE_MPI"IsthisonanMPIsystem?"OFF)i

c++ - C++11 中的 exec 缺少 "missing sentinel"警告

如果您忘记在对exec(3)之一的调用结束时包含NULL标记,GCC会发出有用的警告。功能:#includeintmain(intargc,char**argv){execlp("test","test","arg1");}GCC4.8的示例编译器输出:$g++test.cc-Wformattest.cc:Infunction‘intmain(int,char**)’:test.cc:4:32:warning:missingsentinelinfunctioncall[-Wformat=]execlp("test","test","arg1");^$但是,如果您在C++11模式下编译,

c++ - 当返回类型是一个类时,带有尾随返回类型的 GCC 属性警告

当返回类型是类时,GCC4.9.1似乎不喜欢带有尾随返回类型和属性的函数声明。考虑以下简单的测试用例:structbar{inta;bar(inta):a(a){}};autofoo()->bar__attribute__((unused));autofoo()->bar{returnbar(5);}intmain(){return0;}GCC打印关于属性的奇怪警告:argh.cpp:2:41:warning:ignoringattributesappliedtoclasstype‘bar’outsideofdefinition[-Wattributes]autofoo()->bar_

c++ - __sync_val_compare_and_swap 与 __sync_bool_compare_and_swap

我一直在思考这两个函数的返回值。__sync_bool_compare_and_swap函数的返回值似乎有明显的好处,即我可以用它来判断交换操作是否发生。但是,我看不到__sync_val_compare_and_swap的返回值的良好用途。首先,让我们有一个函数签名供引用(来自GCC文档减去varargs):type__sync_val_compare_and_swap(type*ptr,typeoldvaltypenewval);我看到的问题是__sync_val_compare_and_swap的返回值是*ptr的旧值。准确地说,这是在设置了适当的内存屏障后,此函数的实现所看到的

c++ - 两次 GCC 编译相同的输入,生成两个不同的代码(第二个错误)

我有时会遇到GCC(4.6.4,Ubuntu12.04)的奇怪问题,我正在使用它来编译一个巨大的项目(数百个文件和数十万行代码),但我最近发现了一些东西。在某些编译之后(似乎是随机发生的),我得到了一段特定的代码,编译方式不同且错误,导致我的代码出现未定义的行为:classsomeDerivedClass:publicsomeBaseClass{public:structanotherDerived:publicanoterBaseClass{voidSomeMethod(){someMember->someSetter(2);}}}其中“someSetter”定义为:voidsome

c++ - 为什么使用 extern struct {} foo,会触发无效的 fPIC required 错误消息?

我正在构建一个共享库,它具有如下所示的相应代码和编译规则://x.Cstruct{shortlen;chars[32700];}foo;//u.Cexternstruct{shortlen;chars[32700];}foo;voidblah(void){foo.s[0]=0;}$CXX-cx.C-fPIC$CXX-cu.C-fPIC$CXX-shared-ox.so.1-Wl,-soname,x.so.1x.ou.o此代码使用intel(v13-v16)编译器和clang编译器(v3.6)进行编译和链接,但使用g++(版本4.9.2)时出现链接错误:u.o:relocationR_X

c++ - gcc 中的模糊重载,适用于 msvc

以下代码在msvc18.00上编译良好,但在gcc4.9.1上编译失败:#includetemplateclassNum{};classZero{};templateNumoperator+(Num,Num){return{};}templateZerooperator+(Num,Num){return{};}intmain(){Numone;Nummone;Numnull;autoa=one+one;static_assert(std::is_same>::value,":(");autob=one+mone;static_assert(std::is_same::value,":(

c++ - 错误 : expected primary-expression before ‘int’

我正在使用:gcc--版本gcc(Ubuntu4.9.2-0ubuntu1~14.04)4.9.2我正在尝试编译以下程序:#include#includeusingnamespacestd;intmain(){cout但是得到如下错误:g++-fcilkplusCilk_1.cppCilk_1.cpp:Infunction‘intmain()’:Cilk_1.cpp:9:12:error:expectedprimary-expressionbefore‘int’cilk_for(inti=0;i怎么了?谢谢 最佳答案 来自linkC