Kol*_*nya 97 c++ constructor class
第1,2,3,4行有什么区别?
我什么时候使用?
为什么第3行打印constructor Foo和第7行返回错误而第8行没有?
#include <iostream>
using namespace std;
class Foo
{
public:
Foo ( )
{
cout << "constructor Foo\n";
}
};
class Bar
{
public:
Bar ( Foo )
{
cout << "constructor Bar\n";
}
};
int main()
{
/* 1 */ Foo* foo1 = new Foo ();
/* 2 */ Foo* foo2 = new Foo;
/* 3 */ Foo foo3;
/* 4 */ Foo foo4 = Foo::Foo();
/* 5 */ Bar* bar1 = new Bar ( *new Foo() );
/* 6 */ Bar* bar2 = new Bar ( *new Foo );
/* 7 */ Bar* bar3 = new Bar ( Foo foo5 );
/* 8 */ Bar* bar3 = new Bar ( Foo::Foo() );
return 1;
}
Run Code Online (Sandbox Code Playgroud)
Luc*_*ore 118
/* 1 */ Foo* foo1 = new Foo ();
Run Code Online (Sandbox Code Playgroud)
Foo在动态内存中创建类型的对象.foo1指向它.通常,您不会在C++中使用原始指针,而是使用智能指针.如果Foo是POD类型,这将执行值初始化(这里不适用).
/* 2 */ Foo* foo2 = new Foo;
Run Code Online (Sandbox Code Playgroud)
与之前相同,因为Foo不是POD类型.
/* 3 */ Foo foo3;
Run Code Online (Sandbox Code Playgroud)
创建在自动存储中调用的Foo对象foo3.
/* 4 */ Foo foo4 = Foo::Foo();
Run Code Online (Sandbox Code Playgroud)
使用复制初始化来创建在自动存储中Foo调用的对象foo4.
/* 5 */ Bar* bar1 = new Bar ( *new Foo() );
Run Code Online (Sandbox Code Playgroud)
使用Bar的转换构造函数Bar在动态存储中创建类型的对象.bar1是指向它的指针.
/* 6 */ Bar* bar2 = new Bar ( *new Foo );
Run Code Online (Sandbox Code Playgroud)
和之前一样.
/* 7 */ Bar* bar3 = new Bar ( Foo foo5 );
Run Code Online (Sandbox Code Playgroud)
这只是无效的语法.你不能在那里声明一个变量.
/* 8 */ Bar* bar3 = new Bar ( Foo::Foo() );
Run Code Online (Sandbox Code Playgroud)
如果bar3没有在7中宣布,将按照相同的原则工作和工作到5和6 .
5和6包含内存泄漏.
类似的语法new Bar ( Foo::Foo() );不常见.通常是new Bar ( (Foo()) );-最令人烦恼的解析的额外括号帐户. (校正的)
Mik*_*our 18
foo4通过默认构造,复制和销毁临时对象来初始化; 通常,这被省略,给出与3相同的结果.Foo foo5是宣言,而不是表达; function(和constructor)参数必须是表达式.Foo()而不是等效Foo::Foo()(或确实Foo::Foo::Foo::Foo::Foo())创建临时我什么时候使用?
Bar从临时创建动态时Foo.第1,2,3,4行将调用默认构造函数。它们本质上是不同的,因为1,2是动态创建的对象,而3,4是静态创建的对象。
在第7行中,您可以在参数调用内创建一个对象。因此,这是一个错误。
第5行和第6行是内存泄漏的邀请。
| 归档时间: |
|
| 查看次数: |
184161 次 |
| 最近记录: |