草庐IT

c++ - 此类代码中 gcc 和 clang 之间的不同行为

intmain(){std::vectordelimiters={",",";"};std::cout我在gcc和clang之间得到不同的答案clang7.0.0打印出来,gcc8.2.0报错terminatecalledafterthrowinganinstanceof'std::length_error'what():cannotcreatestd::vectorlargerthanmax_size()Aborted哪个编译器是正确的? 最佳答案 两个编译器都是正确的,因为你的代码有未定义的行为。你掉进了陷阱。{",",";"}

c++ - 为什么 gcc 的选项 "-Wstrict-prototypes"对 C++ 无效?

这是一个警告,我和网上的很多人,请参阅在C++代码上运行gcc时:cc1plus:warning:commandlineoption"-Wstrict-prototypes"isvalidforAda/C/ObjCbutnotforC++警告文本非常清楚:'C++'不在集合[Ada/C/ObjC]中,所以我完全不知道为什么gcc在编译C++代码时会发出此警告。(仅供引用,尽管有C++代码,我们仍打开此标志的原因是因为它主要是C代码,我们选择了严格(高级)警告选项列表,但我们添加了一些C++代码。我的问题是:为什么这个警告对C++无效?警告选项的gcc文档,来自http://gcc.gn

c++ - GCC 4.4/4.5 unique_ptr 不适用于 unordered_set/unordered_map

有什么地方可以确认吗?我不确定是GCC的问题还是我的代码的问题。例如,以下代码无法编译:#include#includeusingnamespacestd;intmain(){unordered_set>s;unique_ptrp(newint(0));s.insert(move(p));return0;}错误信息太大,我不想放在这里。GCC版本为4.5.3,编译标志为-std=gnu++0x。也在4.4.5上测试过。 最佳答案 GCC4.6.1按原样接受您的代码,我认为它没有任何问题(即关联容器的value_type必须是Empl

c++ - 将 gcc 属性与 C++11 属性语法一起使用

我正在尝试使用GCCattributes与C++11syntax.例如这样的事情:staticvoid[[used]]foo(void){//...}但我得到以下信息:warning:‘used’attributeignored[-Wattributes]staticvoid[[used]]foo(void)^为什么该属性被忽略?是否可以将GCC属性用作C++属性? 最佳答案 [[gnu::used]]staticvoidfoo(void){}首先,属性只能出现在特定的地方,否则你会得到:x.cc:1:13:warning:attr

c++ - 如何为忘记的返回语句打开 gcc 警告?

如何为忘记的返回语句打开gcc警告?它应该在以下情况下警告我:intfoo(){std::cout我知道-Wall会打开该警告,但它会启用太多其他警告。 最佳答案 根据gcc的onlinedocumentation,-Wall打开:-Waddress-Warray-bounds(onlywith-O2)-Wc++0x-compat-Wchar-subscripts-Wenum-compare(inC/Objc;thisisonbydefaultinC++)-Wimplicit-int(CandObjective-Conly)-Wim

c++ - 使用 GCC 和 C++11 实现类型 "long double"

我尝试搜索有关longdouble的信息,到目前为止,我了解到编译器对它的实现有所不同。在Ubuntu(XUbuntu)Linux12.10上使用GCC时,我得到了这个:doublePId=acos(-1);longdoublePIl=acos(-1);std::cout.precision(100);std::cout输出:PId8:3.141592653589793115997963468544185161590576171875PIl16:3.141592653589793115997963468544185161590576171875有人明白为什么他们输出(几乎)相同的东西吗

c++ - 为什么在 GCC/C++ 中弹出 "pragma GCC diagnostic push"警告?

#pragmaGCCdiagnosticpushitpop:warning:expected[error|warning|ignored]afterâ#pragmaGCCdiagnosticâ为什么?我在Linux中使用GCC。我有一个问题,如果我不能使用pop/push,忽略只影响编译的cpp,而不影响其他cpp?如果其他一些包括上限,是否影响它? 最佳答案 #pragmaGCCdiagnosticpush和#pragmaGCCdiagnosticpop是addedingcc4.6.您使用的是旧版本。这些pragma通常与其他#p

c++ - clang 等同于 -rdynamic gcc 标志是什么?

我找不到任何类似的选项可以将所有函数名称包含到最终发布的二进制文件中。还是clang默认执行此操作? 最佳答案 这道题的正确答案是-Wl,-export_dynamic而不是-Wl,--export-dynamic。-Wl,--export-dynamic只有在ELF平台上使用GNU链接器时才是正确的。这个问题是关于OSX的。来源:http://www.opensource.apple.com/source/ld64/ld64-236.3/src/ld/Options.cpp...elseif(strcmp(arg,"-export

c++ - 奇怪的 gcc 错误 : stray '\NNN' in program

我的开源库中弹出了以下问题,我无法弄清楚发生了什么。我的两个用户有类似的(gcc)编译器错误:/home/someone/Source/src/._regex.cpp:1:1:warning:nullcharacter(s)ignored/home/someone/Source/src/._regex.cpp:1:error:stray‘\5’inprogram/home/someone/Source/src/._regex.cpp:1:error:stray‘\26’inprogram/home/someone/Source/src/._regex.cpp:1:error:stray

c++ - 将结构成员初始化为 0 (gcc -Wextra)

我想将所有结构成员初始化为0。常见的解决方案是做这样的事情:structfoobar={0}我创建了这个例子:#includestructStru2{intc;intd;};structStru1{inta;Stru2b;};intmain(){structStru1aaa={0};returnaaa.b.c;}然后我用这个参数编译(gcc4.6.3)它,以确保ANSI如何处理这个gcc-Wall-Wextra-pedantic-ansimain.cpp我收到以下警告:main.cpp:Infunction‘intmain()’:main.cpp:36:28:warning:missi