/*
传统多线程调用
*/
#include <stdio.h>
#include <pthread.h>#include <assert.h>
#include <stdlib.h>
#include <time.h>
typedef struct __counter_t
{
volatile int value;
pthread_mutex_t lock;
} counter_t;
counter_t *c;
void init(counter_t *c)
{
c->value=0;
pthread_mutex_init(&c->lock,NULL);
}
void increment(counter_t *c)
{
pthread_mutex_lock(&c->lock);
c->value++;
pthread_mutex_unlock(&c->lock);
}
void decrement(counter_t *c)
{
pthread_mutex_lock(&c->lock);
c->value--;
pthread_mutex_unlock(&c->lock);
}
int get(counter_t *c)
{
pthread_mutex_lock(&c->lock);
int rc=c->value;
pthread_mutex_unlock(&c->lock);
return rc;
}
void *mytread(void *id)
{
printf("开始执行%d\n",(int)(*((int *)id)));
long i;
for(i = 0;i<1e7;i++){
increment(c);
}
return NULL;
}
int main(void)
{
double start,finish;
start=clock();
pthread_t p1,p2,p3,p4;
int a = 0,b = 1,a1 = 2,b2 = 3;
c=malloc(sizeof(counter_t));
init(c);
pthread_create(&p1,NULL,mytread,&a);
pthread_create(&p2,NULL,mytread,&b);
pthread_create(&p3,NULL,mytread,&a1);
pthread_create(&p4,NULL,mytread,&b2);
finish = clock();
duration = (double)(finish - start)/CLOCKS_PER_SEC;
printf("程序运行的时间%f\n",duration);
}