 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.
Merci pour vos commentaires !
Demandez à l'IA
Demandez à l'IA
Posez n'importe quelle question ou essayez l'une des questions suggérées pour commencer notre discussion
Can you explain more about how malloc() and free() work together?
What happens if I forget to free memory allocated with malloc()?
Why is it important to set a pointer to NULL after freeing it?
Awesome!
Completion rate improved to 2.63 Malloc and Free
Malloc and Free
Glissez pour afficher le menu
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.
Merci pour vos commentaires !