临时空间
临时空间具有常性,什么时候会产生临时空间呢?
临时对象和临时空间都具有常性
1、函数传值返回
把aa拷贝给临时空间,如果是很大的对象并且进行深拷贝,消耗会很大
证明:
这是list模拟实现迭代器的==和!=重载时,while( it! = lt.end() ) 时 lt.end()传值返回产生了临时空间
2、表达式的返回值是一个临时变量
x + y
func() + 3
类型转换
3、无论是强制类型转换还是隐式类型转换,都会开辟临时空间,因为不能修改原本变量的值,所以形参要加上const,因为临时空间具有常性
4、匿名对象具有常性
问题:
eax和xmm0到底算不算临时空间呢?
列表初始化
多参数构造函数隐式类型转换
一切皆可用{}初始化,并且可以不写=
建议日常定义,不要去掉=,但是我们要能看懂
Point p1 = {3,3}
{3,3} 先构造一个临时对象,在拷贝构造,但是编译器优化了,本质是调用构造函数
因为类型转换都会产生临时对象,临时对象具有常性所以const Point& r 引用要加上const
这三个本质都是调用构造函数
new的场景
第三行用列表初始化会比匿名对象舒服一些(字少)
禁止隐式类型转换:
initializer_list
多参数隐式类型转换只能和构造函数参数个数一样,而initializer_list可以的个数可以和构造不一样,他们都是构造,但是是有区别的
C++11把直接写的括号定义成了initializer_list类型
initializer_list底层用两个指针一个指向开始,一个指向结尾的下一个
vector添加了initializer_list的构造函数
map的initializer_list构造函数
initializer_lits作为operator= () 的参数,支持括号赋值