 Malloc and Free
Malloc and Free
These functions enable us to create new objects not during compilation but during program execution, allowing us to use dynamic memory allocation.
malloc()
Before, to allocate memory for our data, we would simply declare:
int x;
Now, with the malloc() function, we can allocate memory dynamically:
int* pX = (int*)malloc(4);
The malloc() function requires the number of bytes to be allocated as its argument. If you're unsure of the byte size needed, but you know the type of data to be stored, you can adjust the expression like this:
int* pX = (int*)malloc(sizeof(int));
What's next?
Notice that we're assigning the result of the malloc() function to a pointer. This means malloc() returns an address!
The prefix (int*) is an explicit cast. We manually specify the desired type. For instance:
double x = 3.14;
int y = (int)x;   // `y` = 3
Main.c
1234567891011#include <stdio.h> #include <stdlib.h> // new header file! int main() { int* pX = (int*)malloc(sizeof(int)); printf("Address of allocated memory: %p\n", pX); return 0; }
Note
Remember to include the header file
stdlib.h. It contains the prototype for themalloc()function.
To store data at the address provided by the malloc() function, we use the dereference operator.
Main.c
123456789101112#include <stdio.h> #include <stdlib.h> int main() { int* pX = (int*)malloc(sizeof(int)); *pX = 100; printf(" Value %d at address %p\n", *pX, pX); return 0; }
Is it possible to free up memory? – Yes, but only the memory allocated by malloc() and similar functions.
free()
This function is used with pointers. To illustrate, let's expand on the example above:
Main.c
1234567891011121314151617#include <stdio.h> #include <stdlib.h> int main() { int* pX = (int*)malloc(sizeof(int)); *pX = 100; printf(" Value %d at address %p\n", *pX, pX); free(pX); printf("After `free()` value %d at address %p\n", *pX, pX); return 0; }
Interestingly, even after we "delete" a pointer, it remains functional, but the value stored in its associated memory location becomes garbled.
This leads to a problem: an occupied memory cell now holds unreliable data. To prevent these pointers, the used pointer should be reset to NULL.
Main.c
1234567891011121314151617#include <stdio.h> #include <stdlib.h> int main() { int* pX = (int*)malloc(sizeof(int)); *pX = 100; printf("Value %d at address %p\n", *pX, pX); free(pX); pX = NULL; return 0; }
Setting a pointer to NULL after freeing its memory is a clear way to indicate that the pointer no longer references a valid memory location.
Always check if the pointer is NULL before using it to ensure you're not accessing invalid or already allocated memory.
Takk for tilbakemeldingene dine!
Spør AI
Spør AI
Spør om hva du vil, eller prøv ett av de foreslåtte spørsmålene for å starte chatten vår
Awesome!
Completion rate improved to 2.63 Malloc and Free
Malloc and Free
Sveip for å vise menyen
These functions enable us to create new objects not during compilation but during program execution, allowing us to use dynamic memory allocation.
malloc()
Before, to allocate memory for our data, we would simply declare:
int x;
Now, with the malloc() function, we can allocate memory dynamically:
int* pX = (int*)malloc(4);
The malloc() function requires the number of bytes to be allocated as its argument. If you're unsure of the byte size needed, but you know the type of data to be stored, you can adjust the expression like this:
int* pX = (int*)malloc(sizeof(int));
What's next?
Notice that we're assigning the result of the malloc() function to a pointer. This means malloc() returns an address!
The prefix (int*) is an explicit cast. We manually specify the desired type. For instance:
double x = 3.14;
int y = (int)x;   // `y` = 3
Main.c
1234567891011#include <stdio.h> #include <stdlib.h> // new header file! int main() { int* pX = (int*)malloc(sizeof(int)); printf("Address of allocated memory: %p\n", pX); return 0; }
Note
Remember to include the header file
stdlib.h. It contains the prototype for themalloc()function.
To store data at the address provided by the malloc() function, we use the dereference operator.
Main.c
123456789101112#include <stdio.h> #include <stdlib.h> int main() { int* pX = (int*)malloc(sizeof(int)); *pX = 100; printf(" Value %d at address %p\n", *pX, pX); return 0; }
Is it possible to free up memory? – Yes, but only the memory allocated by malloc() and similar functions.
free()
This function is used with pointers. To illustrate, let's expand on the example above:
Main.c
1234567891011121314151617#include <stdio.h> #include <stdlib.h> int main() { int* pX = (int*)malloc(sizeof(int)); *pX = 100; printf(" Value %d at address %p\n", *pX, pX); free(pX); printf("After `free()` value %d at address %p\n", *pX, pX); return 0; }
Interestingly, even after we "delete" a pointer, it remains functional, but the value stored in its associated memory location becomes garbled.
This leads to a problem: an occupied memory cell now holds unreliable data. To prevent these pointers, the used pointer should be reset to NULL.
Main.c
1234567891011121314151617#include <stdio.h> #include <stdlib.h> int main() { int* pX = (int*)malloc(sizeof(int)); *pX = 100; printf("Value %d at address %p\n", *pX, pX); free(pX); pX = NULL; return 0; }
Setting a pointer to NULL after freeing its memory is a clear way to indicate that the pointer no longer references a valid memory location.
Always check if the pointer is NULL before using it to ensure you're not accessing invalid or already allocated memory.
Takk for tilbakemeldingene dine!