C++初始化列表
C++初始化列表
定义一个类对象时,常常使用初始化列表实例化一个对象,在进入构造函数函数体之前对成员变量完成初始化操作。普通成员变量既可以在初始化中初始化,也可以在函数体重赋值;const成员变量只能在初始化列表中赋值。下面对初始化列表进行一个简单介绍:
- 使用初始化列表
#include <iostream>
using namespace std;
class InitTest{
public:
InitTest(int x,int y,int z) : a(x),b(y),c(z){}
public:
void Print() const{
cout<<"a = "<<a<<endl;
cout<<"b = "<<b<<endl;
cout<<"c = "<<c<<endl;
}
private:
int a;
int b;
int c;
};
int main(int argc, char** argv)
{
InitTest test(,,);
test.Print();
return ;
}
成员变量被正确赋值,输出:
- 初始化列表必须使用场景1——const成员变量
class InitTest{
public:
InitTest(int x,int y,int z){
a = x; // error C2758: “InitTest::a”: 必须在构造函数基/成员初始值设定项列表中初始化
b = y;
c = z;
}
private:
const int a;
int b;
int c;
};
class InitTest{
public:
InitTest(int x,int y,int z) : a(x){ // OK
b = y;
c = z;
}
public:
void Print() const{
cout<<"a = "<<a<<endl;
cout<<"b = "<<b<<endl;
cout<<"c = "<<c<<endl;
}
private:
const int a;
int b;
int c;
};
- 初始化列表必须使用场景2——成员变量或基类未声明默认构造函数
成员变量未声明默认构造函数
#include <iostream>
using namespace std;
class InitTest{
public:
InitTest(int x,int y,int z) : a(x),b(y),c(z){}
public:
void Print() const{
cout<<"a = "<<a<<endl;
cout<<"b = "<<b<<endl;
cout<<"c = "<<c<<endl;
}
private:
int a;
int b;
int c;
};
class HaveInitTest{
InitTest test1;
public:
HaveInitTest(){}
};
int main(int argc, char** argv)
{
HaveInitTest havetest; // error C2512: “InitTest”: 没有合适的默认构造函数可用
return ;
}
#include <iostream>
using namespace std;
class InitTest{
public:
InitTest(int x,int y,int z) : a(x),b(y),c(z){}
public:
void Print() const{
cout<<"a = "<<a<<endl;
cout<<"b = "<<b<<endl;
cout<<"c = "<<c<<endl;
}
private:
int a;
int b;
int c;
};
class HaveInitTest{
InitTest test1;
public:
HaveInitTest() : test1(,,){}
};
int main(int argc, char** argv)
{
HaveInitTest havetest; // OK
return ;
}
基类未声明默认构造函数
#include <iostream>
using namespace std;
class InitTest{
public:
InitTest(int x,int y,int z) : a(x),b(y),c(z){}
private:
int a;
int b;
int c;
};
class DerivedFromInitTest : public InitTest{
public:
DerivedFromInitTest(){}
};
int main(int argc, char** argv)
{
DerivedFromInitTest dervetest; // error C2512: “InitTest”: 没有合适的默认构造函数可用
return ;
}
#include <iostream>
using namespace std;
class InitTest{
public:
InitTest(int x,int y,int z) : a(x),b(y),c(z){}
private:
int a;
int b;
int c;
};
class DerivedFromInitTest: public InitTest{
public:
DerivedFromInitTest() : InitTest(,,){}
};
int main(int argc, char** argv)
{
DerivedFromInitTest derivetest; // OK
return ;
}
最简单的解决方法是将InitTest的构造函数声明为:InitTest(int x = 0,int y = 0,int z = 0)。
- 初始化列表必须使用场景3——声明为引用类型的成员变量
#include <iostream>
using namespace std;
class InitTest{
public:
InitTest(int &x, int y, int z){
a = x; // error C2758: “InitTest::a”: 必须在构造函数基/成员初始值设定项列表中初始化
b = y;
c = z;
}
private:
int &a;
int b;
int c;
};
class InitTest{
public:
InitTest(int &x, int y, int z) : a(x){ // OK
b = y;
c = z;
}
private:
int &a;
int b;
int c;
};
数据成员初始化顺序
数据成员按照他们在类中的声明顺序来初始化,而不是按照在初始化列表中出现的顺序。
#include <iostream>
using namespace std;
class InitTest{
public:
InitTest(const int a, const int b) : x(a),y(b){}
private:
int x;
int y;
};
int main(int argc, char** argv)
{
InitTest test(,); // test.x = 10, test.y = 20
return ;
}
#include <iostream>
using namespace std;
class InitTest{
public:
InitTest(const int a, const int b) : y(b),x(a + y){}
private:
int x;
int y;
};
int main(int argc, char** argv)
{
InitTest test(,); // test.x未初始化, test.y = 20
return ;
}
!总结:初始化列表中,先声明数据不依赖后声明数据来初始化。
C++初始化列表的更多相关文章
- C++中使用初始化列表的情况
http://blog.csdn.net/iceshirley/article/details/5688696 要理解这个问题,从概念上,我们要知道一点,那就是构造函数的执行过程会分成两个阶段:隐式或 ...
- C++11新特性——初始化列表 initializer_list
破事水: 由于最近数据结构有个实验报告说是要对字符串进行排序,想偷个懒不想一个一个地赋值,虽然可以用strcpy和传入二级指针的形式直接写,但是这样感觉不美观漂亮. 然后就去膜了一下C++11的新特性 ...
- 【c++】必须在类初始化列表中初始化的几种情况
转自:http://www.cnblogs.com/kaituorensheng/p/3477630.html 1. 类成员为const类型 2. 类成员为引用类型 #include <iost ...
- C++语法 初始化列表 数组引用
只能在初始化列表initilizationlist中初始化的有: 1.const修饰的数据成员或者reference参考 2.基类的构造函数 注意,数组不能引用,亦即以下代码是不对的 void fun ...
- C++定义构造函数必须使用初始化列表的场合
明其理,而知其然也. 先给理论.1. 初始化 != 赋值. a.初始化代表为变量分配内存. 变量在其定义处被编译器初始化(编译时). 在函数中, 函数参数初始化发生在函数调用时(运行时). b.赋值代 ...
- C++-什么时候需要在类的构造函数中使用初始化列表
1,如果基类没有default构造函数,则意味着其不能自己初始化.如果其被派生,派生类的构造函数要负责调用基类的构造函数,并传递给它需要的参数.下例中Base 2,如果类成员没有默认构造函数.下例中E ...
- C++:四种必须使用初始化列表情况
[c++]必须在类初始化列表中初始化的几种情况 1. 类成员为const类型 2. 类成员为引用类型 复制代码 #include <iostream> using namesp ...
- C++类构造函数初始化列表
C++类构造函数初始化列表 构造函数初始化列表以一个冒号开始,接着是以逗号分隔的数据成员列表,每个数据成员后面跟一个放在括号中的初始化式.例如: class CExample {public: ...
- C++11初始化列表
[C++11之初始化列表] 在C++03中,在严格遵守POD的定义和限制条件的结构及类型上可以使用初始化列表(initializer list),构想是结构或是数组能够依据成员在该结构内定义的顺序通过 ...
随机推荐
- ES6 对象增强和结构赋值
The enhanced Object literals: ES6 has added some new syntax-based extensions to {} object literal fo ...
- PBOC金融IC卡,卡片与终端交互的13个步骤,简介-第三组
七:终端风险管理-必选但包含可选步骤异常文件:终端检查应用主账号是否在异常文件列表(卡号黑名单)中.商户强制联机:商户可以将当前交易强制为联机处理.最低限额:控制交易当前交易金额或同一张卡片连续几笔交 ...
- git hub
如果希望保留生产服务器上所做的改动,仅仅并入新配置项, 处理方法如下:git stashgit pullgit stash pop然后可以使用git diff -w +文件名 来确认代码自动合并的情况 ...
- java:StringBuffer字符处理对象
1.添加字符 public class StringBufferDemo { public static void main(String args[]) { StringBuffer sbf = n ...
- NGUI Atlas Maker sprites with black line issue
NGUI图集中的图,在游戏中显示出来带有黑边的问题. 实际上是因为图片在导入到图集中,图片四周的完全透明的边缘部分会被裁掉,而在图集中的实际大小比图片原始大小小以及图集中图片之间的间距设置得太小导致. ...
- 基础算法之插入排序Insertion Sort
原理 通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入.通常采用in-place排序(即只需用到O(1)的额外空间的排序),因而在从后向前扫描过程中,需要反复把已排序元 ...
- SHAREPOINT 2013 列表之间相互关联
修改内容 1.增加列表设置,隐藏Aid字段操作 SharePoint 列表之间相互关联 例如两张列表之间的父子关系. 思路如下: 列表中新增列表项后会有一个唯一的ID,我们获取到该ID赋予子表即可将两 ...
- 原生js通过prottype写的一个简单拖拽
<!DOCTYPE html> <head> <meta charset="utf-8"/> <title></title&g ...
- Android开发--ListView的应用
1.简介 ListView用于以列表的形式展示数据.它在装载数据时,不能使用ListView类的add()等相关方法添加,而要借助Adapter对象进行添加.另外,由于 系统提供的Adapter往往不 ...
- nginx、Apache、IIS服务器解决 413 Request Entity Too Large问题方法汇总
一.nginx服务器 nginx出现这个问题的原因是请求实体太长了.一般出现种情况是Post请求时Body内容Post的数据太大了,如上传大文件过大.POST数据比较多. 处理方法 在nginx.co ...