数组对象初始化,其类具有某种ctor/dtor
Array objects initialization whose class has some ctor / dtor
我想通过使用如下初始化语句来实现数组对象的初始化。
TestClass array[5] = {
TestClass("test1"),
TestClass("test2"),
TestClass("test3"),
TestClass("test4"),
TestClass("test5")
};
根据一些权威的书,比如C++的ARM(带注释的参考手册),它似乎说这是初始化具有构造函数/析构函数的对象数组的方法。接下来,我刚刚创建了以下示例代码,看看会发生什么。
#include <iostream>
#include <sstream>
#include <string>
class TestClass
{
public:
TestClass(const char* name) : name_(name)
{
std::cout << "Ctor(const char*) : " << name_ << std::endl;
}
~TestClass()
{
std::cout << "Dtor() : " << name_ << std::endl;
}
TestClass() : name_("")
{
}
void print()
{
std::cout << "obj:" << name_ << std::endl;
}
private:
TestClass(const TestClass& rhs);
std::string name_;
};
int main()
{
TestClass array[5] = {
TestClass("test1"),
TestClass("test2"),
TestClass("test3"),
TestClass("test4"),
TestClass("test5")
};
for (unsigned int i = 0; i < sizeof(array)/sizeof(array[0]); ++i) {
array[i].print();
}
return EXIT_SUCCESS;
}
至于使用GNUGCC(4.1.2)编译上述源代码的第一次尝试,它因生成以下内容而失败。
error: ‘TestClass::TestClass(const TestClass&)’ is private
所以我理解这意味着为了允许对象数组初始化,它需要"复制构造函数"。然后,我尝试通过引入用户定义的(公共)复制构造函数来编译上面的代码,如下所示。
TestClass::TestClass(const TestClass& rhs) : name_(rhs.name_)
{
std::cout << "Copy Ctor : " << name_ << std::endl;
}
我可以成功地编译源代码。然而,当我执行上面构建的程序时,我得到了以下输出。
Ctor(const char*) : test1
Ctor(const char*) : test2
Ctor(const char*) : test3
Ctor(const char*) : test4
Ctor(const char*) : test5
obj:test1
obj:test2
obj:test3
obj:test4
obj:test5
Dtor() : test5
Dtor() : test4
Dtor() : test3
Dtor() : test2
Dtor() : test1
我想知道的是,
为什么我们不能将复制构造函数声明为私有?
为什么没有调用用户定义的复制构造函数(我本以为输出应该在某个地方包含"copy Ctor:xxxx"。但我没能得到。所以我知道用户定义的副本构造函数没有被调用。)
事实上,我真的不确定以上是GNUGCC特有的,还是这是C++语言规范。。。如果你们中的一些人能给我上面的正确指针,我将不胜感激。
编译器会删除副本,但副本构造函数仍然必须是可访问的。
无论编译器是否使用复制构造函数,它都必须是可访问的,即它不能是私有的。在这种情况下,编译器可以通过直接使用const-char*构造函数来避免使用复制构造函数,但它仍然需要一个可访问的复制构造函数。这是ARM中没有涵盖的事情,已经过时了。
相关文章:
- std::is_base_of表示ctor编译错误
- 对复制 CTOR 和 CTOR 的未定义引用
- C++ 基本 CTOR 说明 - 为什么不调用赋值/复制构造函数
- C++成功复制动态分配的 obj 而不复制 ctor?
- 如何测试采用 std::initializer_list 的 ctor 具有编译时已知长度?
- 冲突的 CLANG"虚拟 dtor"和"已弃用的复制运算符"警告
- 为什么 std::optional::value_or 没有默认 ctor 类型的专用化?
- 在CTOR vs Connect方法中提升套接字与stream_socket端点
- 给定一个右值,为什么移动ctor比常量复制ctor更匹配
- std::任何只用于移动的模板,其中副本ctor内的static_assert等于编译错误,但为什么
- C2436 '{ctor}':构造函数初始值设定项列表中的成员函数或嵌套类
- 为什么在 ctor 的参数列表中将成员"x"的类型替换为"decltype(x)"会破坏类模板参数推导?
- 对象的 ctor 和 dtor 必须在同一线程上吗?
- 返回对象时CTOR/DTOR的顺序
- boost::shared_ptr,CTOR 中有一个原子增量,但 DTOR 中有两个原子递减
- RAII 失败 - 为什么此C++代码泄漏?- 在尝试块中加入 CTOR 阻止 DTOR
- c++全局/堆栈实例ctor/dtor调用静态函数时崩溃
- 数组对象初始化,其类具有某种ctor/dtor
- 为什么VS2010向导在ctor和dtor中添加void类型
- C++ CTOR 和 DTOR 的工作方式不同