My questions is, suppose we have two classes A and B. I want to have an object of B in class A.
Should I use,
class A
{
public:
A();
~A();
B* b;
};
or
class A
{
public:
A();
~A();
B b;
};
As far as I know, in the first scenario, I can initialize the object *b
using new
operator and for the second scenario, I can initialize b
using an initialization list if I don't want to use the default constructor of class B
. Which is more convenient to use?
Second one is more convenient , because you don't need to manage memory yourself. No
new
, nodelete
.If you go with the first one, then you probably have to implement Rule of Three also (in C++03):
Or, Rule of Five (in C++11):
The underlying idea behind this rule is the following:
So unless you've strong reason why you need pointer version (such as in case when you need polymorphic behavior), you must go with the second approach (the non-pointer approach).
If you want an object of class B in A, then you must use the second. The first doesn't give you an object of type B in A, it gives you an object of type
B*
in A.The second is also more convenient for almost all purposes. Only use a pointer when you have to, and even then resource-handling is more convenient with a smart pointer rather than a
B*
.In this scenario, the non-pointer version is more convenient. You don't need to worry about invoking
delete
at the correct time, and therefore you don't need to worry about destructors, copy constructors and copy assignment operators.In general, you should avoid dynamically-allocated memory as much as possible.
Use the second, try to avoid using
new
as much as possible in C++ unless you are using RAII.It depends.
Even if you use the pointer, you can initialize the member in the initialization list, but that's not your biggest concern.
There are advantages and disadvantages to both:
Using a pointer:
Pros:
the class will be smaller in memory
you only need a forward declaration to the other class - no need to include the other header in your header
can use derived objects from
B
as membersCons:
Using an object:
Pros:
Cons:
can only use objects of the base class. What if you want to derive from
B
?more memory for each instance
constructor of
B
will be called on construction ofA
you need the full definition of
B
inside the headerI'll edit my answer if I think of more.