Open In App

What is a Memory Heap?

What is Heap memory?

Heaps are memory areas allocated to each program. Memory allocated to heaps can be dynamically allocated, unlike memory allocated to stacks.

As a result, the heap segment can be requested and released whenever the program needs it. This memory is also global, which means that it can be accessed and modified from wherever in the program it is allocated instead of being localized by the function in which it is allocated. Dynamically allocated memory is referenced using ‘pointers’, which in turn leads to slight performance degradation over the use of local variables (on the stack).



Heap memory is also known as “dynamic” memory.

Heap memory is different from local stack memory. It not only differs in the way it allocates and deallocates variables when the function is called but also in the way it deallocates the variable when the function exit. This memory “block” is usually determined automatically according to the size of the object they are creating. 



Advantages of heap memory:

Disadvantages of heap memory:

Problems that can be solved with heap memory:

The following are some important points about Garbage Collection.

Example of creating memory in heap:




int Geeks()
{
    // Nothing allocated yet excluding the
    // pointer itself, which is allocated
    // here on the stack.
    char* p;
 
    // Memory allocated on the stack.
    bool flag = true;
 
    if (flag) {
 
        // Create 1000 bytes on the stack
        char buffer[1000];
 
        // Create 1000 bytes on the heap
        p = new char[1000];
    }
 
    // buffer is deallocated here but pointer
    // p is not Here occurs a memory leak,
    // We have to call delete[] p;
}




/*package whatever //do not write package name here */
 
import java.io.*;
 
class GFG {
    public static void main(String[] args)
    {
        // java does not have direct access to memory
        // location ie. pointers so we use Object
        Object p;
 
        // Memory allocated on the stack.
        boolean flag = true;
 
        if (flag)
        {
            // Create 16 bytes on the stack memory
            char buffer;
 
            // Create 1000 bytes on the heap memory
            p = new Object[1000];
        }
    }
}
//This code is contributed by Akshay Tripathi(akshaytripathi19410)




def Geeks():
    # Nothing allocated yet excluding the
    # pointer itself, which is allocated
    # here on the stack.
    p = None
 
    # Memory allocated on the stack.
    flag = True
 
    if flag:
        # Create 1000 bytes on the stack
        buffer = bytearray(1000)
 
        # Create 1000 bytes on the heap
        p = bytearray(1000)
 
    # buffer is deallocated here but pointer
    # p is not. Here occurs a memory leak,
    # We have to call del p
 
 # this code is contributed by bhardwajji




<script>
// Define a function called Geeks
function Geeks() {
// Declare a pointer variable p
// No memory has been allocated yet, except for the pointer itself on the stack
let p;
 
// Declare a boolean variable flag and set it to true
let flag = true;
 
if (flag) {
     
// Declare a char array called buffer and allocate 1000 bytes on the stack
let buffer = new Array(1000);
 
// Allocate 1000 bytes on the heap and assign the pointer to p
p = new Array(1000);
}
 
    // buffer is deallocated here but pointer
    // p is not Here occurs a memory leak,
    // We have to call delete[] p;
}
// This code is contributed by Aman Kumar.
</script>




using System;
 
class Program
{
    static void Main(string[] args)
    {
        // In C#, the equivalent of a Java Object is an object type
        object p;
 
        // Memory allocation on the stack
        bool flag = true;
 
        if (flag)
        {
            // Create 16 bytes on the stack memory
            char buffer;
 
            // Create 1000 bytes on the heap memory
            p = new object[1000];
        }
    }
}

Points to Remember:

1 It is stored in computer RAM memory just like the stack.
2 It has a slower allocation of variables in comparison to variables on the stack.
3 It works on the basis of using on-demand to allocate a block of data for use by the program.
4 It can have fragmentation when there are a lot of allocations and deallocations.
5 In C++, variables on the heap must be destroyed manually and never fall out of scope. The data is freed with delete, delete[], or free.
6 In C++ or C, data created on the heap will be pointed to by pointers and allocated with new or malloc respectively.
7 We can use heap memory if you don’t exactly know the actual size of data needed at run time or if you need to allocate a lot of data.
8 It is responsible for memory leaks.

Article Tags :