linux 线程同步消息队列,Linux线程同步(消息队列)

分两个c源文件queue.c main.c,代码如下:

queue.c

#include

struct msg {

int data;

struct msg* next_msg;

};

struct msg * workq;

pthread_mutex_t qlock = PTHREAD_MUTEX_INITIALIZER;

pthread_cond_t  qready =  PTHREAD_COND_INITIALIZER;

void init_queue(void){

pthread_mutex_lock(&qlock);

workq=NULL;

pthread_mutex_unlock(&qlock);

}

void enqueue_msg(struct msg* mp){

pthread_mutex_lock(&qlock);

mp->next_msg=workq;

workq=mp;

pthread_mutex_unlock(&qlock);

pthread_cond_signal(&qready);

}

struct msg *queue_msg(void){

struct msg *mp;

pthread_mutex_lock(&qlock);

while(workq==NULL)

pthread_cond_wait(&qready,&qlock);

mp=workq;

workq=mp->next_msg;

pthread_mutex_unlock(&qlock);

return mp;

}

main.c

#include #include #include #include

struct msg {

int data;

struct msg* next_msg;

};

extern void enqueue_msg(struct msg* mp);

extern void init_queue(void);

extern struct msg * queue_msg(void);

void process_msg(int pid){

struct msg *mp;

printf("thread %d created.\n",pid);

for(;;){

mp=queue_msg();

printf("thread %d deal the msg.data is %d  \n",pid,mp->data);

struct msg msgx;

msgx.data=mp->data+1;

msgx.next_msg=NULL;

enqueue_msg(&msgx);

//sleep(3);

}

}

void * thr_fn(void*arg){

process_msg(*(int*)arg);

return ((void*)1);

}

void main(){

pthread_t  tid1;

pthread_t  tid2;

int err;

int pid=1;

err=pthread_create(&tid1,NULL,thr_fn,&pid);

if(err!=0){

printf("can't create thread %d \n",err);

}

int pid1=2;

err=pthread_create(&tid2,NULL,thr_fn,&pid1);

if(err!=0){

printf("can't create thread %d \n",err);

}

printf("create thread success.\n");

sleep(1);

struct msg msg1;

msg1.data=100;

msg1.next_msg=NULL;

init_queue();

enqueue_msg(&msg1);

printf("add a  msg .\n");

sleep(3);

printf("OK\n");

pthread_join(tid1,NULL);

}

在ubuntu14.04下编译 :

gcc  queue.c main.c -o  milk  -lpthread

chmod a+x milk

./milk

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值