cmake+gcc解决extended initializer lists only available with -std=c++11 or -std=gnu++11

来源:互联网 发布:混沌与秩序2救赎数据库 编辑:程序博客网 时间:2024/05/17 21:40

有时,我们需要一个结构体变量做为参数传递给函数,后面又不需要再用到这个结构体变量,所以如果专门定义一个变量,再将这个变量传递给函数就显得挺罗嗦。
就像下面这段代码,tmpStruct只是起到一个数据包装的作用,调用test()之后并不再用到,所以这个变量就显示有些多余 。

#include <iostream>struct _stA{    char *a;    int b;    int c;}stA;void test(_stA n){    cout<<n.a<<endl;}int main() {    char str[]="hello!";    _stA tmpStruct{str,0,1};//定义一个变量装载str等数据;    //或者写成_stA tmpStruct={str,0,1}也是可以的    test(tmpStruct);//将tmpStruct做为变量传递给test}

这时我们可以将数据包装成临时结构体变量(或者叫匿名变量)传递给要调用函数。所以调用方式可以简化成下面这样:

int main() {    char str[]="hello!";    test(_stA{str,0,1});//编译器会为_stA{str,0,1}结构体生成一个临时变量}

但是重新编译,会出下面警告

J:\workspace\codemgr\cmimpl\testmd5.cpp: In function ‘int main()’:
J:\workspace\codemgr\cmimpl\testmd5.cpp:26:11: warning: extended initializer lists only available with -std=c++11 or -std=gnu++11
test(_stA{str,0,1});

它的意思大概就是_stA{str,0,1}这种用列表初始化结构的方式要在c++ 11标准中才支持。
initializer lists是c++11的特性 (参见 std::initializer_list(点击打开链接))

so,对于cmake生成的项目,我们就需要在CMakeLists.txt中添加如下编译选项

add_definitions(“-std=c++11”)

或者

add_definitions(“-std=gnu++11)

然后重新生成makefile,编译警告就消失了。

0 0
原创粉丝点击