APUE Learning Example Source Code
guowenxue
2020-04-14 ed572bf7f37a64efb3417a21e2db1329288607ee
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
#include <stdio.h>
#include <string.h>
#include <errno.h>
#include <stdlib.h>
#include <unistd.h>
#include <pthread.h>
 
void *thread_worker1(void *args);
void *thread_worker2(void *args);
 
typedef struct worker_ctx_s
{
    int               shared_var;
    pthread_mutex_t   lock;
} worker_ctx_t;
 
int main(int argc, char **argv)
{
    worker_ctx_t     worker_ctx;
    pthread_t        tid;
    pthread_attr_t   thread_attr; 
 
    worker_ctx.shared_var = 1000;
    pthread_mutex_init(&worker_ctx.lock, NULL);
 
 
    if( pthread_attr_init(&thread_attr) )
    {
        printf("pthread_attr_init() failure: %s\n", strerror(errno));
        return -1;
    }
 
    if( pthread_attr_setstacksize(&thread_attr, 120*1024) )
    {
        printf("pthread_attr_setstacksize() failure: %s\n", strerror(errno));
        return -1;
    }
 
    if( pthread_attr_setdetachstate(&thread_attr, PTHREAD_CREATE_DETACHED) )
    {
        printf("pthread_attr_setdetachstate() failure: %s\n", strerror(errno));
        return -1;
    }
 
    pthread_create(&tid, &thread_attr, thread_worker1, &worker_ctx);
    printf("Thread worker1 tid[%ld] created ok\n", tid);
 
    pthread_create(&tid, &thread_attr, thread_worker2, &worker_ctx);
    printf("Thread worker2 tid[%ld] created ok\n", tid);
 
    while(1)
    {
        printf("Main/Control thread shared_var: %d\n", worker_ctx.shared_var);
        sleep(10);
    }
 
    pthread_mutex_destroy(&worker_ctx.lock);
}
 
void *thread_worker1(void *args)
{
    worker_ctx_t        *ctx = (worker_ctx_t *)args;
 
    if( !args )
    {
        printf("%s() get invalid arguments\n", __FUNCTION__);
               pthread_exit(NULL);
    }
 
    printf("Thread workder 1 [%ld] start running...\n", pthread_self());
 
    while(1)
    {
        pthread_mutex_lock(&ctx->lock);
 
        printf("+++: %s before shared_var++: %d\n", __FUNCTION__, ctx->shared_var);
        ctx->shared_var ++;
        sleep(2);
        printf("+++: %s after sleep shared_var: %d\n", __FUNCTION__, ctx->shared_var);
 
        pthread_mutex_unlock(&ctx->lock);
 
        sleep(1);
    }
 
    printf("Thread workder 1 exit...\n");
 
    return NULL;
}
 
void *thread_worker2(void *args)
{
    worker_ctx_t        *ctx = (worker_ctx_t *)args;
 
    if( !args )
    {
        printf("%s() get invalid arguments\n", __FUNCTION__);
               pthread_exit(NULL);
    }
 
    printf("Thread workder 2 [%ld] start running...\n", pthread_self());
 
    while(1)
    {
        if(0 != pthread_mutex_trylock(&ctx->lock) )
        {
            continue;
        }
 
        printf("---: %s before shared_var++: %d\n", __FUNCTION__, ctx->shared_var);
        ctx->shared_var ++;
        sleep(2);
        printf("---: %s after sleep shared_var: %d\n", __FUNCTION__, ctx->shared_var);
 
        pthread_mutex_unlock(&ctx->lock);
 
        sleep(1);
    }
 
    printf("Thread workder 2 exit...\n");
 
    return NULL;
}