C++中,A a =100;调用了几次构造函数?几次复制构造函数?
6个回答
展开全部
A a = 100;编译的时候创建并初始化对象a,与语句A a(100)等价。镇模基
注意:该码态句与A a; a = 100;并御谨不等价。
所以:A a = 100;调用了一次A(int)构造函数,并没调用复制构造函数,也没创建临时对象。
追问
连临时对象都没有创建,你确定?你真的确定?
追答
确定,你为什么不去验证下呢。
class A
{
public:
A (int a){
cout << "构造" << endl;
}
A (A &t){
cout << "拷贝构造" << endl;
}
void operator =(int a){
cout << "重载=" << endl;
}
};
int main()
{
A a = 10; //只会打印”构造“!
}
展开全部
A a =100;隐式转换为A a =A(100);
A(100)的确有一拆搜次构造函数,但是由于生成的是临时对象,编译器可以使之不调用复制构造函数(当然也不排除“完全不优化而直接编译为调用复制构造函散型数”的可能),而直接把A(100)生成的临时对象的内容“移动”到a中。因此,这里调用C++11标准中新增的“移动构造函数”的可能性远大于调用复制构造函数的可能性。实际上,所有的现代编译器都旅掘历不会产生复制构造函数的调用
A(100)的确有一拆搜次构造函数,但是由于生成的是临时对象,编译器可以使之不调用复制构造函数(当然也不排除“完全不优化而直接编译为调用复制构造函散型数”的可能),而直接把A(100)生成的临时对象的内容“移动”到a中。因此,这里调用C++11标准中新增的“移动构造函数”的可能性远大于调用复制构造函数的可能性。实际上,所有的现代编译器都旅掘历不会产生复制构造函数的调用
追问
你的意思是说,以上赋值,编译器一般不创建临时对象,而是直接调用构造函数初始化了?
追答
是的
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
不是这样理笑羡宽解的, A a就是创建一碰亮个对象, 而不是什么临时对象, 触发的默认构造函数,
而派宽a = 100则是将100整数赋值给a, 但a是个类, 需要重载=号运算符, 不然编译器不知道将100赋值a里哪个成员.
而派宽a = 100则是将100整数赋值给a, 但a是个类, 需要重载=号运算符, 不然编译器不知道将100赋值a里哪个成员.
追问
不是吧 大哥,书上代码并没有重载=号运算符,也能通过的,A a =100; 究竟过程是怎样的?
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
这里发生了隐式转换,其实和A a(100)一样
追问
1,到底有没有创建临时对象,我想肯定是有的。
2,到底调用了哪些函数,一个都不漏
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
你好,你重载=了吗,若有请说明,若没有,编译是过不去的,语法错误
追问
语法错误?你确定?
追答
绝对的!
临时对象是这样子的:A(100);
希望回答能帮到你,
望采纳!
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询