Previous Lecture lect04 Next Lecture

Code from lecture

https://github.com/ucsb-cs24-f23/cs24-f23-lectures/tree/main/lect04

Topics

Recursion, dynamic memory errors, rule of three!

Rule of three

The questions we ask are:

  1. What is the behavior of these defaults (taking linked lists as our running example)?
  2. When and why do we need to overload these?
  3. What is the outcome we desire to have with the overloaded de’tor, copy con’tor and copy assignment operator for the linked list class?

Destructor

In general the destructor is called when a) a stack object goes out of local scope and has to be removed from memory b) delete is called on a pointer that is pointing to an object of the class on the heap

Here are two scenarios where the destructor is called

Case 1:

void foo(){
   LinkedList l1; 
   ....
   ....
   //l1's destructor is called  right after the function returns
}

Case 2:

  LinkedList* p = new LinkedList; // This line may be in any function
  .....
  delete p; // This line may be in a function different from where the object was created with new

Now suppose we had a linked list object (either on the stack or the heap) that has the following elements

l1:1->2->5->null

Copy constructor

The default copy constructor copies the values of the member variables of a source object to the objects that is being created.

For we created the following linked list in memory:

l1:1->2->5->null

As far as the compiler is concerened its perfectly valid to create a new object l2 that is the copy of l1 as follows:

LinkedList l2(l1); // l2's copy constructor is called and l1 is passed as a parameter

OR

LinkedList l2 = l1; // l2's copy constructor is called and l1 is passed as a parameter

OR we could create the new object on the heap as follows

LinkedList* p = new LinkedList(l1); 

In all the above cases the default copy constructor of the new object is called.

Copy assignment operator

The default assignment operator works like the copy constructor except it copies values from one existing object to another object that already exists

For we had two linked lists in memory:

l1:1->2->5->null
l2:10->20->50->60->null

The copy assignment operator will be called in all of the following cases:

l2 = l1; // l2's copy assignment is called and l1 is passed as a parameter

OR

l2 = l2; //l2's copy assignment is called and l2 is passed as a parameter!