如何解决C ++中的类实例声明
| 假设我有ClientList类,并且已经这样声明。class ChatMgr
{
private:
ClientList _userlist;
ClientList *_userlist;
}
那有什么区别呢?我知道第二个是实例的地址,我需要使用new对其进行初始化才能使用它。然后对于第一个,是否可以不进行初始化就直接访问类中的所有数据成员?
提前致谢....
解决方法
没错,
_userList
是ClientList
类的实际实例,因此当ChatMgr
被调用时(它的构造函数被调用)而被初始化,而*_userlist
是一个指针,未进行初始化。
, 有什么区别?
ClientList _userlist;
将类别“ 2”的对象添加为类别“ 3”的成员
_userlist
本身就是一个对象,因此,当创建ChatMgr
对象时,编译器将调用其构造函数。 ѭ8的所有初始化应在其自己的构造函数的ѭ11或ѭ12中进行。
ClientList *_userlist;
将指向“ѭ2”类的对象的指针添加为“ѭ3”类的成员
*_userlist
应该在使用前指向有效的东西,因为它只是一个指针,您需要将其指向有意义的东西才能使用它。
最好在类ChatMgr
的Initializer List
中使用initialize。
对于第一个,是否可以不进行初始化就访问类内部的所有数据成员?
如Q1所述,是的,您可以访问_userlist
的内容而无需对其进行初始化,因为在编译器调用ClientList
构造函数时,隐式发生了初始化。
, 如果我没记错的话,第一个通过构造函数并创建ClientList,第二个仅保存潜在ClientList的地址。
由于您尚未分配要指向的内容,因此在创建对象并将其新地址分配给指针之前,后者将无法使用。
, ClientList _userlist;
-_userlist
是一个对象。
ClientList *_userlist;
-_userlist
是指向ClientList
类型的对象的指针。
在第一种情况下,只要在实例化当前ChatMgr
对象之前看到ClientList
的定义,就可以访问数据成员。所以,
class ClientList
{
// ...
};
class ChatMgr
{
ClientList _userList ;
// ...
};
, 我担心您可能会混淆这些概念。请记住以下两者之间的区别:
House H;
House *L;
H自己存储房子。 L存储房屋的地址。
, 您需要在使用指针之前对其进行初始化,但是实例可能会在构造函数中进行初始化。
您的班级有2位成员:
ClientList _userlist;
ClientList *_userlist;
ClientList _userlist
是ClientList
的实例。 constructor3ѭ构造函数将调用其构造函数,并假设该构造函数正确初始化了所有内容,则可以开始使用它。
ClientList *_userlist
是指向ClientList
实例的指针。可以通过使用new
或为其分配其他实例的地址来初始化它。完成此操作后,指针将被初始化,并且指针指向的实例也将被初始化(ѭ36call将调用ClientList
构造函数)。
, 更改成员变量的名称,以便代码实际进行编译:
class ChatMgr
{
private:
ClientList _userlist;
ClientList *_pUserlist;
}
除非已初始化,否则您永远无法访问任何对象。不同之处在于,无论您是否显式创建ChatMgr
对象,_userList
都会被初始化,因此没有(合法)方式可以在不初始化的情况下获取此类成员。
_pUserlist
(OTOH)是一个指针,一个POD,除非您明确进行了初始化,否则它根本不会初始化(甚至不会初始化为0
/NULL
)。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。