#tutorial13#
Dynamic allocation of memory is a very important subject in C. It allows building complex data structures such as linked lists. Allocating memory dynamically helps us to store data without initially knowing the size of the data in the time we wrote the program.
To allocate a chunk of memory dynamically, we have to have a pointer ready to store the location of the newly allocated memory. We can access memory that was allocated to us using that same pointer, and we can use that pointer to free the memory again, once we have finished using it.
Let's assume we want to dynamically allocate a person structure. The person is defined like this:
typedef struct {
    char * name;
    int age;
} person;
myperson argument, we use the following syntax:person * myperson = malloc(sizeof(person));
Note that
sizeof is not an actual function, because the compiler interprets it and translates it to the actual memory size of the person struct.To access the person's members, we can use the
-> notation:myperson->name = "John";
myperson->age = 27;
free:free(myperson);
myperson variable itself, it simply releases the data that it points to. The myperson variable will still point to somewhere in the memory - but after calling myperson we are not allowed to access that area anymore. We must not use that pointer again until we allocate new data using it. 
No comments:
Post a Comment
Note: only a member of this blog may post a comment.