linux-c-programming.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* thread: reentrant question
@ 2009-12-24 18:41 Randi Botse
  2009-12-24 19:30 ` vinit dhatrak
  0 siblings, 1 reply; 6+ messages in thread
From: Randi Botse @ 2009-12-24 18:41 UTC (permalink / raw)
  To: linux-c-programming

Hi all,

I'm now learning thread reentrancy on Linux, so i write simple codes
for demonstration:

#include <stdio.h>
#include <stdlib.h>
#include <pthread.h>

void *func(void *data)
{
    char *ptr;

    ptr = malloc(8);
    printf("thread%i -> ptr at: %p\n", *(int*) data, ptr);
    free(ptr);
    return NULL;
}

#define NTHREAD 5

int main(void)
{
    pthread_t thread[NTHREAD];
    int i;

    for (i = 0; i < NTHREAD; i++)
        if (pthread_create(&thread[i], NULL, func, (void*) &i))
            return -1;
    for (i = 0; i < NTHREAD; i++)
        pthread_join(thread[i], NULL);
    return 0;
}


I know the func() function is not reentrant, worst printf() debugging
told me that's each thread pointer to character (ptr) may has same
address, like this output:

thread1 -> ptr at: 0x9a80128
thread1 -> ptr at: 0x9a80138
thread2 -> ptr at: 0x9a801d8
thread4 -> ptr at: 0x9a801d8
thread4 -> ptr at: 0x9a801d8

I try to modify the func() by not free ptr to be:

void *func(void *data)
{
    char *ptr;

    ptr = malloc(8);
    printf("thread%i -> ptr at: %p\n", *(int*) data, ptr);
    /* free(ptr); */
    return NULL;
}

And the result is i always got different address of each thread's ptr, such as:

thread0 -> ptr at: 0x8db2098
thread1 -> ptr at: 0x8db2138
thread2 -> ptr at: 0x8db21d8
thread3 -> ptr at: 0x8db2278
thread4 -> ptr at: 0x8db2318

Can you explain me why this happen? how about my printf() debugging
method? it's works for this demonstration?
Thanks before.

              - Randi

^ permalink raw reply	[flat|nested] 6+ messages in thread

end of thread, other threads:[~2009-12-27 13:12 UTC | newest]

Thread overview: 6+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2009-12-24 18:41 thread: reentrant question Randi Botse
2009-12-24 19:30 ` vinit dhatrak
2009-12-26  5:32   ` Randi Botse
2009-12-26 10:42     ` Michał Nazarewicz
2009-12-26 21:23     ` vinit dhatrak
2009-12-27 13:12       ` Randi Botse

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).