Skip to content
Related Articles

Related Articles

Improve Article
Save Article
Like Article

new and delete operators in C++ for dynamic memory

  • Difficulty Level : Easy
  • Last Updated : 22 Oct, 2021

Dynamic memory allocation in C/C++ refers to performing memory allocation manually by programmer. Dynamically allocated memory is allocated on Heap and non-static and local variables get memory allocated on Stack (Refer Memory Layout C Programs for details).
What are applications? 

  • One use of dynamically allocated memory is to allocate memory of variable size which is not possible with compiler allocated memory except variable length arrays.
  • The most important use is flexibility provided to programmers. We are free to allocate and deallocate memory whenever we need and whenever we don’t need anymore. There are many cases where this flexibility helps. Examples of such cases are Linked List, Tree, etc.

How is it different from memory allocated to normal variables? 
For normal variables like “int a”, “char str[10]”, etc, memory is automatically allocated and deallocated. For dynamically allocated memory like “int *p = new int[10]”, it is programmers responsibility to deallocate memory when no longer needed. If programmer doesn’t deallocate memory, it causes memory leak (memory is not deallocated until program terminates). 
How is memory allocated/deallocated in C++? 
C uses malloc() and calloc() function to allocate memory dynamically at run time and uses free() function to free dynamically allocated memory. C++ supports these functions and also has two operators new and delete that perform the task of allocating and freeing the memory in a better and easier way.
This article is all about new and delete operators. 

Want to learn from the best curated videos and practice problems, check out the C++ Foundation Course for Basic to Advanced C++ and C++ STL Course for foundation plus STL.  To complete your preparation from learning a language to DS Algo and many more,  please refer Complete Interview Preparation Course.


new operator

The new operator denotes a request for memory allocation on the Free Store. If sufficient memory is available, new operator initializes the memory and returns the address of the newly allocated and initialized memory to the pointer variable. 

  • Syntax to use new operator: To allocate memory of any data type, the syntax is: 
pointer-variable = new data-type;
  • Here, pointer-variable is the pointer of type data-type. Data-type could be any built-in data type including array or any user defined data types including structure and class. 
// Pointer initialized with NULL
// Then request memory for the variable
int *p = NULL; 
p = new int;   


// Combine declaration of pointer 
// and their assignment
int *p = new int; 
  • Initialize memory: We can also initialize the memory for built-in data types using new operator. For custom data types a constructor is required (with the data-type as input) for initializing the value. Here’s an example for the initialization of both data types : 
pointer-variable = new data-type(value);
int *p = new int(25);
float *q = new float(75.25);

// Custom data type
struct cust
    int p;
    cust(int q) : p(q) {}

cust* var1 = new cust;    // Works fine, doesn't require constructor


cust* var1 = new cust();        // Works fine, doesn't require constructor

cust* var = new cust(25)        // Notice error if you comment this line
  • Allocate block of memory: new operator is also used to allocate a block(an array) of memory of type data-type
pointer-variable = new data-type[size];
  • where size(a variable) specifies the number of elements in an array. 
        int *p = new int[10]
  • Dynamically allocates memory for 10 integers continuously of type int and returns pointer to the first element of the sequence, which is assigned to p(a pointer). p[0] refers to first element, p[1] refers to second element and so on. 



Normal Array Declaration vs Using new 
There is a difference between declaring a normal array and allocating a block of memory using new. The most important difference is, normal arrays are deallocated by compiler (If array is local, then deallocated when function returns or completes). However, dynamically allocated arrays always remain there until either they are deallocated by programmer or program terminates.
What if enough memory is not available during runtime? 
If enough memory is not available in the heap to allocate, the new request indicates failure by throwing an exception of type std::bad_alloc, unless “nothrow” is used with the new operator, in which case it returns a NULL pointer (scroll to section “Exception handling of new operator” in this article). Therefore, it may be good idea to check for the pointer variable produced by new before using it program. 

int *p = new(nothrow) int;
if (!p)
   cout << "Memory allocation failed\n";


delete operator

Since it is programmer’s responsibility to deallocate dynamically allocated memory, programmers are provided delete operator by C++ language. 

// Release memory pointed by pointer-variable
delete pointer-variable;  

Here, pointer-variable is the pointer that points to the data object created by new

  delete p;
  delete q;

To free the dynamically allocated array pointed by pointer-variable, use following form of delete

// Release block of memory 
// pointed by pointer-variable
delete[] pointer-variable;  

   // It will free the entire array
   // pointed by p.
   delete[] p;



// C++ program to illustrate dynamic allocation
// and deallocation of memory using new and delete
#include <iostream>
using namespace std;
int main ()
    // Pointer initialization to null
    int* p = NULL;
    // Request memory for the variable
    // using new operator
    p = new(nothrow) int;
    if (!p)
        cout << "allocation of memory failed\n";
        // Store value at allocated address
        *p = 29;
        cout << "Value of p: " << *p << endl;
    // Request block of memory
    // using new operator
    float *r = new float(75.25);
    cout << "Value of r: " << *r << endl;
    // Request block of memory of size n
    int n = 5;
    int *q = new(nothrow) int[n];
    if (!q)
        cout << "allocation of memory failed\n";
        for (int i = 0; i < n; i++)
            q[i] = i+1;
        cout << "Value store in block of memory: ";
        for (int i = 0; i < n; i++)
            cout << q[i] << " ";
    // freed the allocated memory
    delete p;
    delete r;
    // freed the block of allocated memory
    delete[] q;
    return 0;


Value of p: 29
Value of r: 75.25
Value store in block of memory: 1 2 3 4 5 

Related Articles:

This article is contributed by Akash Gupta. If you like GeeksforGeeks and would like to contribute, you can also write an article using or mail your article to See your article appearing on the GeeksforGeeks main page and help other Geeks.
Please write comments if you find anything incorrect, or you want to share more information about the topic discussed above.

My Personal Notes arrow_drop_up
Recommended Articles
Page :

Start Your Coding Journey Now!