DYNAMIC MEMORY
ALLOCATION
COMPONENTS OF
MEMORY
#include <stdio.h>
int sum; // global variable
// Declaring gcd and lcm functions, both takes two integer arguments, // (memory will
   not be allocated upon declaring or defining our functions).
int greatestCommonDivisor(int, int);
int leastCommonMultiple(int, int);
// Defining greatest common divisor function (also know as HCF).
int greatestCommonDivisor(int a, int b)
{ while (a && b) {
        if (a > b) { a %= b; }
        else { b %= a; } }
      return a + b; }
// Defining least common multiple function by using greatest common divisor.
int leastCommonMultiple(int a, int b)
{ return (a / greatestCommonDivisor(a, b)) * b; }
int main() {
int x, y;
printf("Enter two values to find their Greatest Common Divisor and Least Common
  Multiple : ");
scanf("%d%d", &x, &y);
printf("Greatest Common Divisor : %d \nLeast Common Multiple : %d",
  greatestCommonDivisor(x, y), leastCommonMultiple(x, y));
sum = greatestCommonDivisor(x, y) + leastCommonMultiple(x, y);
printf("\nSum of GCD and LCM : %d\n", sum);
return 0; }
LIMITATION OF STATIC
MEMORY
THIS ALLOCATION METHOD LEADS TO
 MEMORY WASTAGE.
MEMORY CANNOT BE CHANGED WHILE
 EXECUTING A PROGRAM.
EXACT MEMORY REQUIREMENTS MUST BE
 KNOWN.
IF MEMORY IS NOT REQUIRED, IT CANNOT
 BE FREED.
DYNAMIC MEMORY
ALLOCATION
MEMORY IS ALLOCATED AT RUNTIME.
MEMORY CAN BE ALLOCATED AND
 RELEASED AT ANY TIME.
HEAP MEMORY IS USED HERE.
DYNAMIC MEMORY ALLOCATION IS
 SLOW.
IT IS MORE EFFICIENT AS COMPARED TO
 STATIC MEMORY ALLOCATION
MEMORY CAN BE RESIZED DYNAMICALLY
 OR REUSED.
     DYNAMIC MEMORY
   ALLOCATION FUNCTIONS
malloc() - allocates single block
 of requested memory.
calloc() - allocates multiple block
 of requested memory.
realloc() - reallocates the memory
 occupied by malloc() or calloc()
 functions.
free()frees the dynamically
 allocated memory.
       malloc() FUNCTION
malloc() is a method in C which is used to allocate a
 memory block in the heap section of the memory of
 some specified size (in bytes) during the run-time of a
 C program.
 It is a library function present in the <stdlib.h>
 header file.
malloc() function takes size in bytes as an argument
 and returns a void pointer, so we have to type cast
 the malloc() function to the required data type.
 malloc() does not initialises the allocated memory
 block, so initially it contains a garbage value.
Defined in header <stdlib.h> as : void* malloc( size_t
 size );       size : number of bytes to be allocated
      malloc() FUNCTION
ptr = (cast-type*) malloc(byte-size)
For Example:
      ptr = (int*) malloc(100 *
 sizeof(int));
EXAMPLE
// C Program to dynamically allocate an int ptr
#include <stdio.h>
 #include <stdlib.h>
int main() {
// Dynamically allocated variable, sizeof(char) = 1
   byte.
 char *ptr = (char *)malloc(sizeof(char));
if (ptr == NULL) { printf("Memory Error!\n"); }
 else {
 *ptr = 'S';
printf("%c", *ptr); }
return 0; }
        calloc() FUNCTION
calloc() is a method in C which is also used to
 allocate memory blocks in the heap section, but it
 is generally used to allocate a sequence of memory
 blocks (contiguous memory) like an array of
 elements. It is also present in <stdlib.h> header
 file.
Defined in header <stdlib.h> as :
       void* calloc( size_t num, size_t size );
calloc() function takes two arguments, first is the
 size of the array (number of elements) and second
 is the sizeof() data type (in bytes) of which we have
 to make an array.
       calloc() FUNCTION
ptr = (cast-type*)calloc(n, element-size);
For Example:
       ptr = (int*) calloc(5, sizeof(int));
    EXAMPLE
// C Program to dynamically allocate an array using calloc()
 #include <stdio.h>
#include <stdlib.h>
int main() {
int n;
scanf("%d", &n);
// Dynamically allocated array of size 10 using calloc()
// array elements are initialized with 0
// arr stores the base address of the memory block
char *str = (char *)calloc(n, sizeof(char));
if (str == NULL) { printf("Memory Error!\n"); }
else {
// initializing array with char variables
for (int i = 0; i < n; i++) {
char ch;
scanf("%c", &ch);
 *(str + i) = ch; }
// printing array using pointer
 for (int i = 0; i < n; i++) { printf("%c", *(str + i)); } }
 return 0; }
        free() FUNCTION
free() as the name suggests is used to free
 or deallocate a memory block previously
 allocated using malloc() and calloc()
 functions during run-time of our program.
Defined in header <stdlib.h> as :
       void free( void* ptr );
free() takes one argument and it is the
 pointer containing the address of the
 memory block that is to be freed or
 deallocated.
        free() FUNCTION
free(ptr);
For Example:
       ptr = (int*) calloc(5, sizeof(int));
       free(ptr);
EXAMPLE
// C Program to dynamically allocate an int ptr
#include <stdio.h>
 #include <stdlib.h>
int main() {
// Dynamically allocated variable, sizeof(char) = 1 byte.
 char *ptr = (char *)malloc(sizeof(char));
if (ptr == NULL) { printf("Memory Error!\n"); }
 else {
 *ptr = 'S';
printf("%c", *ptr); }
// deallocating the memory
free(ptr);
return 0; }
            realloc() FUNCTION
realloc() is also a method in C that is generally used to
 reallocate a memory block, here re-allocate means to
 increase or decrease the size of a memory block
 previously allocated using malloc() or calloc() methods.
It can also be used to completely allocate or deallocate
 a memory block on its own
General syntax :
       (cast-data-type *)realloc(ptr, new-size-in-bytes)
realloc() takes two arguments, one is the pointer
 pointing the the memory which is to be realloacted
 and second is the new size in bytes.
Defined in header <stdlib.h> as : void *realloc( void
 *ptr, size_t new_size );
       realloc() FUNCTION
 ptr = realloc(ptr, newSize);
 For Example:
       ptr = (int*) calloc(5, sizeof(int));
        ptr = (int*) calloc(ptr, 10*sizeof(int));
       free(ptr);
EXAMPLE
     MALLOC() VS CALLOC()
     malloc()                 calloc()
                              It is a function
     It is a function that
                              that assigns more
     creates one block of
1.                            than one block of
     memory of a fixed
                              memory to a
     size.
                              single variable.
     It only takes one        It takes two
2.
     argumemt                 arguments.
                              It is used to
     It is used to indicate   indicate
3.
     memory allocation        contiguous
                              memory allocation
        STATIC VS DYNAMIC MEMORY
S.No Static Memory Allocation                      Dynamic Memory Allocation
     In the static memory allocation, variables
                                                   In the Dynamic memory allocation, variables get
1    get allocated permanently, till the program
                                                   allocated only if your program unit gets active.
     executes or function call finishes.
     Static Memory Allocation is done before       Dynamic Memory Allocation is done during
2
     program execution.                            program execution.
     It uses stack for managing the static         It uses heap for managing the dynamic
3
     allocation of memory                          allocation of memory
4    It is less efficient                          It is more efficient
                                                   In Dynamic Memory Allocation, there is memory
     In Static Memory Allocation, there is no
5                                                  re-usability and memory can be freed when not
     memory re-usability
                                                   required
     In static memory allocation, once the
                                              In dynamic memory allocation, when memory is
6    memory is allocated, the memory size can
                                              allocated the memory size can be changed.
     not change.
       STATIC VS DYNAMIC MEMORY
S.No Static Memory Allocation                     Dynamic Memory Allocation
                                                  This allows reusing the memory. The user can
     In this memory allocation scheme, we         allocate more memory when required. Also, the
7
     cannot reuse the unused memory.              user can release the memory when the user
                                                  needs it.
     In this memory allocation scheme,
                                                  In this memory allocation scheme, execution is
8    execution is faster than dynamic memory
                                                  slower than static memory allocation.
     allocation.
9    In this memory is allocated at compile time. In this memory is allocated at run time.
     In this allocated memory remains from start In this allocated memory can be released at any
10
     to end of the program.                      time during the program.
     Example: This static memory allocation is Example: This dynamic memory allocation is
11
     generally used for array.                 generally used for linked list.