C++ Memory Management

Memory management refers to the process of managing the computer memory while assigning the space to the program’s variable to improve the overall performance.

Requirement of Memory Management.

We know that data in arrays are stored in a homogeneous way. And we allocate the memory during the array declaration. But in some situations, we may not know how much memory to allocate or how much space the data may require until runtime, so to overcome this situation we declare an array with a maximum size but here the memory is unused and wasted. So to increase the array size, we can manually allocate the memory during run-time and this allocating and freeing of memory refers to dynamic memory allocation in C++ programming.

Now, we know that in C programming, we use malloc() or calloc() functions to dynamically allocate the memory to a variable and free() function is used to free the memory. The same task is obtained in C++ with the use of new and delete Operators. Let us understand them individually.


C++ new Operator.

Just like malloc() or calloc(), the new operator is used to allocate the memory to a variable and arrays. The following is the way of using the new operator.

// declare an int pointer
int* pointerVar;

//using the new keyword for dynamic allocation 
pointerVar = new int;

//value assigned to new allocate memory
*pointerVar = 45;

We use malloc() function in C, but it still exists in C++ but we avoid the use of malloc() in C++. The new operator has its own advantages, the main advantage is that it creates a new object in C++ which is the main concept of C++ as it involves OOP.

It is also a Good practice to check if the free store has been used or not. You can check in the following manner.

int* pointerVar = NULL;

if(!(pointerVar = new double )) 
{
   cout << "Error Message" <<endl;
   exit(1);
}

C++ delete Operator

We use delete to free up dynamically allocated space that is to delete the dynamic memory once we no longer required it. It means deallocating the memory. The syntax for the delete operator is:

delete pointerVar;

//For arrays
delete [] pointerVar; 

Let us go through a simple C++ example to understand better.

#include <iostream>
using namespace std;

int main() {
    // Initailizing pointer with Null
    int* pointerVar = NULL;

    // allocating memory dnamically
    pointerVar = new int;

    // assigning value to the memory
    *pointerVar = 458;
    

    cout << "Its Value: " << *pointerVar << endl;

    // deallocating the memory
    delete pointerVar;

    return 0;
}

Output:

Its Value: 458

You can also see we deallocated the memory at the end after its use.


new and delete Operators for Arrays

Now let us see the use of new and delete operators in arrays. Dynamic allocation increases the efficiency of memory management, especially in arrays.

The syntax or way to allocate memory and deallocate memory is done in the following way in c++.

//Allocating memory
pointerVar = new data-type[size]; 

//Deallocating memory
delete [] pointerVar;  

The syntax is for one dimensional array. You can also allocate memory to multi dimensional array in the following way:

//Allocating memory to multi dimensional array
pointerVar= new double [row][col];

//Deallocating multi dimensional array
delete [] pionterVar;

As you can see deallocation is same for both one and multi dimensional arrays.

Now let us see an C++ example for dynamic memory allocation in array.

#include <iostream>
using namespace std;

int main() 
{
    int number;
    float* ptr;
    
    cout << "How many students are present in your class: ";
    cin >> number;
    
    //allocating memory
    ptr = new float[number];

    cout << "Enter their Maths marks: " << endl;
    for (int i = 0; i < number; ++i) 
    {
        cout << "Roll " << i + 1 << ": ";
        cin >> *(ptr + i);
    }

    cout << "\nEntered Marks for each student." << endl;
    for (int i = 0; i < number; ++i)
        cout << "Roll " << i + 1 << ": " << *(ptr + i) << endl;

    // releasing the ptr memory
    delete[] ptr;

    return 0;
}

Output:

How many students are present in your class: 5
Enter their Maths marks: 
Roll 1: 68
Roll 2: 90
Roll 3: 84
Roll 4: 77
Roll 5: 96

Entered Marks for each student.
Roll 1: 68
Roll 2: 90
Roll 3: 84
Roll 4: 77
Roll 5: 96

new and delete Operators for Objects

As said earlier, a new operator is also used to create new objects in C++. Let us understand through an example.

#include <iostream>
using namespace std;

class Employee 
{
   int salary;

   public:

    // constructor
    Employee() : salary(25000) {}

    void empSalary() 
    {
        cout << "Salary: " << salary << endl;
    }
};

int main() 
{
    // Employee Objects Dynamically
    Employee* ptr = new Employee();

    //calling empSalary funciton from Employee class
    ptr->empSalary();

    // releasing pointer
    delete ptr;

    return 0;
}

Output:

Salary: 25000

In the above program, we created a Employee class where salary variable is initialized using the constructor. An in the main function, we created an object of the Employee class using a new operator and used a pointer to point to the address.

As soon as we create the object the salary is initialized by the constructor and we use the following code to call the function empSalary() from the Employee class