I was curious about what exactly a pointer holds, after malloc()
was used to allocate memory space? The manpage tells me that calloc()
initializes the allocated memory space with zero.
The malloc() function allocates size bytes and returns a pointer to the allocated memory. The memory is not initialized. If size is 0, then malloc() returns either NULL, or a unique pointer value that can later be successfully passed to free().
and
The calloc() function allocates memory for an array of nmemb elements of size bytes each and returns a pointer to the allocated memory. The memory is set to zero. If nmemb or size is 0, then calloc() returns either NULL, or a unique pointer value that can later be successfully passed to free().
I created a really short example program in C, to C(haha) for myself:
int main() {
char *dynamic_chars;
unsigned amount;
printf("how much bytes you want to allocate?\n");
scanf("%d", &amount);
dynamic_chars = (char*)malloc(amount*sizeof(char));
printf("allocated:\n%s\n", dynamic_chars);
free(dynamic_chars);
return 0;
}
However when executing this code, it just outputs nothing. If I initialize the memory my self for example initializing every single byte with 0xFFFF
using a loop, then the program shows me exactly what I expect. The memory space actually exists, since I wont get an error claiming that I am trying to access uninitialized variables or so.
Since memory space is usually not deleted but marked as rewritable I wonder if by executing my program, shouldn't I be able to see random previously used Bytes of memory? But I wont see anything, so I am really confused about how exactly malloc()
works.
Another thing about malloc()
or maybe memory usage in general, that is interesting about my program:
If I use calloc()
, to allocate memory, I can trace the actual memory usage of my program, by e.g. monitoring it. For example, if I tell my program, to allocate 1.000.000.000 Bytes of memory per calloc()
I will see the following in my System monitor:
As you can probably imagine, when using malloc()
, I wont see nothing. I understand, that just by allocating memory, I am not really using it at that time, but I am still confused about why my operating system (unix derivate) won't recognize it as being used. Since malloc()
just like calloc()
returns a physical address to a memory location I don't get, how this memory area seems to be not actually reserved by the OS. Elsewise I could see it in the System Monitor right?
If I should rather post this as a new question, please let me know. But I think since the question is still about how malloc()
works it fits in here.
The malloc subsystem manages a logical memory object called a heap. The heap is a region of memory that resides in the application's address space between the last byte of data allocated by the compiler and the end of the data region.
In C, the library function malloc is used to allocate a block of memory on the heap. The program accesses this block of memory via a pointer that malloc returns. When the memory is no longer needed, the pointer is passed to free which deallocates the memory so that it can be used for other purposes.
The malloc() function allocates a buffer of size bytes. Use free() or realloc() to free the block of memory. Because the malloc() implementation uses signed, 32-bit integers to represent the size internally, you can't allocate more than 2 GB in a single allocation.
I also learned that memory dynamically allocated using malloc is allocated on the heap section of the process.
Malloc is also known as a memory allocation function. Malloc () dynamically allocates a large block of memory of the specified size. Returns a pointer of type void cast to any shape. A malloc allocates contiguous blocks of main memory and deallocates it when no longer needed.
No, malloc()
returns uninitialized memory, the contents of which is indeterminate. So, attempt to use the value invokes undefined behavior.
Quoting C11
, annex §J.2, Undefined behavior
The value of the object allocated by the
malloc
function is used
In this case, %s
expects a null-terminated char
array. However, the content of dynamic_chars
is indeterminate, so there may very well be no null-terminator, at all, which will cause the out-of-bound memory access, which in turn invokes the UB.
Quoting C11
, chapter §7.22.3.5, The malloc
function (emphasis mine):
The
malloc
function allocates space for an object whose size is specified bysize
and whose value is indeterminate.
That said, please see this discussion on why not to cast the return value of malloc()
and family in C
..
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With