自动初始化
Automatically initialized?
本文关键字:初始化 更新时间:2023-10-16
我的课程的开头是:
class Player{
private:
Cardpile hand;
...
}
其中纸堆是另一个类。如果我这样做Player *p=new Player();
手会自动初始化吗?我问这个是因为我一直试图找出一个分段错误。我在代码中到处查找。我能想到的最后一件事是hand
没有初始化。
编辑:这是我得到的分割错误。卡牌是卡牌堆中的一个类。我知道卡片和卡片堆都有效。
Program received signal SIGSEGV, Segmentation fault.
0x0000000000402ac0 in __gnu_cxx::new_allocator<Card*>::construct (this=0x6070a8, __p=0x4015c6, __val=@0x7fffffffe6d8) at /usr/include/c++/4.4/ext/new_allocator.h:105
105 { ::new((void *)__p) _Tp(__val); }
编辑:卡堆类:
class Cardpile : private vector<Card*> {
public:
using vector<Card*>::size;
using vector<Card*>::at;
Cardpile ();
...
}
Cardpile::Cardpile(){}
编辑:这是一个很酷的事实:p = = NULL不检查p是否启动。我想这就是为什么我不断遇到分段错误的原因。
如果未在 Player
构造函数中显式成员初始化hand
,则将使用 Cardpile
的默认构造函数。
如果尚未定义默认构造函数,编译器将创建一个。
当你编译你的程序并将其与-g
链接时,gdb 可以显示你的程序崩溃的堆栈跟踪:
gdb program core
然后在 GDB 中输入 bt
.这将在分段错误时显示完整的调用堆栈。
这取决于Cardpile
是什么。如果是 POD,则不:
class Cardpile1{
int x;
};
如果不是,那么是的:
class Cardpile2{
Cardpile2() : x(0) {}
int x;
};
这两种情况都会存在hand
,但如果Cardpile
被定义为 POD,则从中读取是非法的。
class Player{
public:
Cardpile1 hand1;
Cardpile2 hand2;
};
Player p;
p.hand1.x; //illegal
p.hand2.x; //legal
相关文章:
- 是否可以初始化不可复制类型的成员变量(或基类)
- C++使用整数的压缩数组初始化对象
- C++初始化基类
- 多成员Constexpr结构初始化
- 复制列表初始化的隐式转换的等级是多少
- 内联映射初始化的动态atexit析构函数崩溃
- 如何在C++中初始化嵌套类中的2个memeber
- 如何声明特征矩阵,然后通过嵌套循环初始化它
- 没有用于初始化C++中的变量模板的匹配构造函数
- 在未初始化映射的情况下,将值插入到映射的映射中
- C++成员初始化
- 为什么在C++中首先初始化成员类
- 同时具有"聚合初始化"和"模板推导"
- 初始化具有非默认构造函数的std::数组项的更好方法
- 是否可以在编译时初始化数组,以便在运行时不会花费时间?
- 我可以使用条件运算符初始化C风格的字符串文字吗
- 在C和C++中初始化结构中的数组
- 标准是否使用多余的大括号(例如 T{{{10}}})定义列表初始化?
- 在函数内部的声明中初始化数组,并在外部使用它
- 继承:构造函数,初始化C++11中基类的类C数组成员