感谢@阳一指 和@你好我叫孙策 的评论,四年后再更新,更正一些错误,免得误人子弟……
在不考虑用new动态创建对象的情况下,用最普通的
类名 对象名(参数);
的方法创建对象
先贴上最正常最普通的代码
#include<iostream>
using namespace std;
class C{
public:
C(){
cout<<"Hello C++n";
};
C(int m){
cout<<"I love C++n";
};
private:
int n;
};
int main(){
C c;
return 0;
}
OK,现在我们看看运行结果:
OK,预期地运行了第一个构造函数。但如果我们在创建对象时不用原来的句子:
C c;
而是在对象名后面加():
C c();
那会成怎样呢?
修改后代码:
#include<iostream>
using namespace std;
class C{
public:
C(){
cout<<"Hello C++n";
};
C(int m){
cout<<"I love C++n";
};
private:
int n;
};
int main(){
C c();
return 0;
}
没有运行构造函数!也就是说根本就没有在内存中创建对象,只是创建了一个“对象名”!只声明了对象,并没有实例化
如果创建时给它赋一个参数:
#include<iostream>
using namespace std;
class C{
public:
C(){
cout<<"Hello C++n";
};
C(int m){
cout<<"I love C++n";
};
private:
int n;
};
int main(){
C c(1);
return 0;
}
OK,一切正常。
所以,现在问题就很清楚了,当我们以以下形式创建类对象时:
i)类名 对象名
默认调用“对象名()”这个构造函数,在栈内存中存在对象名,在堆内存中存在实际对象;在栈内存中实例化对象;
ii)类名 对象名(一个或以上个参数)
默认调用相应的构造函数,在栈内存中存在对象名,在堆内存中也是存在实际对象的;在栈内存中实例化对象;
iii)类名 对象名()
不调用任何构造函数创建对象,仅在栈内在中存在对象名,在堆内存中并不存在实际的对象;仅声明对象,不在栈内存中实例化
原文链接: https://www.cnblogs.com/traeyee/p/4892410.html
欢迎关注
微信关注下方公众号,第一时间获取干货硬货;公众号内回复【pdf】免费获取数百本计算机经典书籍
原创文章受到原创版权保护。转载请注明出处:https://www.ccppcoding.com/archives/223274
非原创文章文中已经注明原地址,如有侵权,联系删除
关注公众号【高性能架构探索】,第一时间获取最新文章
转载文章受原作者版权保护。转载请注明原作者出处!