Skip to main content

Use delete on pointer members in destructors.

Item 6: Use delete on pointer members in destructors.
Most of the time, classes performing dynamic memory allocation will use new in the constructor(s) to allocate
the memory and will later use delete in the destructor to free up the memory. This isn't too difficult to get right
when you first write the class, provided, of course, that you remember to employ delete on all the members that
could have been assigned memory in any constructor.
However, the situation becomes more difficult as classes are maintained and enhanced, because the
programmers making the modifications to the class may not be the ones who wrote the class in the first place.
Under those conditions, it's easy to forget that adding a pointer member almost always requires each of the
following:
 Initialization of the pointer in each of the constructors. If no memory is to be allocated to the pointer in a
particular constructor, the pointer should be initialized to 0 (i.e., the null pointer).
 Deletion of the existing memory and assignment of new memory in the assignment operator. (See also Item
17.)
 Deletion of the pointer in the destructor.
If you forget to initialize a pointer in a constructor, or if you forget to handle it inside the assignment operator,
the problem usually becomes apparent fairly quickly, so in practice those issues don't tend to plague you. Failing
to delete the pointer in the destructor, however, often exhibits no obvious external symptoms. Instead, it
manifests itself as a subtle memory leak, a slowly growing cancer that will eventually devour your address
space and drive your program to an early demise. Because this particular problem doesn't usually call attention
to itself, it's important that you keep it in mind whenever you add a pointer member to a class.
Note, by the way, that deleting a null pointer is always safe (it does nothing). Thus, if you write your
constructors, your assignment operators, and your other member functions such that each pointer member of the
class is always either pointing to valid memory or is null, you can merrily delete away in the destructor without
regard for whether you ever used new for the pointer in question.
There's no reason to get fascist about this Item. For example, you certainly don't want to use delete on a pointer
that wasn't initialized via new, and, except in the case of smart pointer objects (see Item M28), you almost never
want to delete a pointer that was passed to you in the first place. In other words, your class destructor usually
shouldn't be using delete unless your class members were the ones who used new in the first place.
Speaking of smart pointers, one way to avoid the need to delete pointer members is to replace those members
with smart pointer objects like the standard C++ Library's auto_ptr.

Comments

Popular posts from this blog

OWASP Top 10 Threats and Mitigations Exam - Single Select

Last updated 4 Aug 11 Course Title: OWASP Top 10 Threats and Mitigation Exam Questions - Single Select 1) Which of the following consequences is most likely to occur due to an injection attack? Spoofing Cross-site request forgery Denial of service   Correct Insecure direct object references 2) Your application is created using a language that does not support a clear distinction between code and data. Which vulnerability is most likely to occur in your application? Injection   Correct Insecure direct object references Failure to restrict URL access Insufficient transport layer protection 3) Which of the following scenarios is most likely to cause an injection attack? Unvalidated input is embedded in an instruction stream.   Correct Unvalidated input can be distinguished from valid instructions. A Web application does not validate a client’s access to a resource. A Web action performs an operation on behalf of the user without checkin...

CKA Simulator Kubernetes 1.22

  https://killer.sh Pre Setup Once you've gained access to your terminal it might be wise to spend ~1 minute to setup your environment. You could set these: alias k = kubectl                         # will already be pre-configured export do = "--dry-run=client -o yaml"     # k get pod x $do export now = "--force --grace-period 0"   # k delete pod x $now Vim To make vim use 2 spaces for a tab edit ~/.vimrc to contain: set tabstop=2 set expandtab set shiftwidth=2 More setup suggestions are in the tips section .     Question 1 | Contexts Task weight: 1%   You have access to multiple clusters from your main terminal through kubectl contexts. Write all those context names into /opt/course/1/contexts . Next write a command to display the current context into /opt/course/1/context_default_kubectl.sh , the command should use kubectl . Finally write a second command doing the same thing into ...