多线程练习题(二)
来源:互联网 发布:从编程小白到全栈开发 编辑:程序博客网 时间:2024/06/05 10:13
(润和面试题):
子线程循环 3 次,接着主线程循环 6 次,接着又回到子线程循环 3 次,接着再回到主线程又循环6 次,如此循环50次,试写出代码。
/*****************************************************
copyright (C), 2014-2015, Lighting Studio. Co., Ltd.File name:
Author:Jerey_Jobs Version:0.1 Date:
Description:
Funcion List:
*****************************************************/
#include <stdio.h>
#include <stdlib.h>
#include <pthread.h>
#include <string.h>
#include <unistd.h>
#define LOOP 50
pthread_mutex_t mylock = PTHREAD_MUTEX_INITIALIZER;
pthread_cond_t mycond = PTHREAD_COND_INITIALIZER;
int num = 0;
int parm_0 = 0;
int parm_1 = 1;
void * th_fun(void * arg)
{
int i, j;
for(i = 0;i < LOOP; i++)
{
pthread_mutex_lock(&mylock);
while(parm_0 != num)
{
pthread_cond_wait(&mycond, &mylock);
}
printf("thread:\n");
for(j = 0;j < 10; j++)
{
printf("%d", j);
}
printf("\n");
num = (num + 1) % 2;
pthread_mutex_unlock(&mylock);
pthread_cond_signal(&mycond);
}
return (void *) 0;
}
int main()
{
int i, k;
pthread_t id;
void *ret;
pthread_create(&id, NULL, th_fun, NULL);
for(i = 0; i < LOOP; i++)
{
pthread_mutex_lock(&mylock);
while(parm_1 != num)
{
pthread_cond_wait(&mycond, &mylock);
}
printf("main:\n");
for(k = 0; k < 3; k++)
{
printf("%d", k + 6);
}
printf("\n");
num = (num + 1) % 2;
pthread_mutex_unlock(&mylock);
pthread_cond_signal(&mycond);
}
pthread_join(id, &ret);
return 0;
}
0 0
- 多线程练习题(二)
- 多线程练习题(一)
- 多线程练习题(一)
- 多线程练习题(三)
- 基础练习题(二)
- Java练习题(二)
- javascript练习题(二)
- 多线程练习题
- 多线程练习题
- 多线程练习题
- C#课后练习题(二)
- C语言练习题(二)
- 机器学习练习题(二)
- Linux 基础练习题(二)
- C语言练习题(二)
- 练习题:二
- Java基础练习题 (8)多线程
- 短实习---Java多线程(练习题)
- Java虚拟机学习 - 内存调优
- maven报错分析
- Android MultiDex 解析与使用
- 浅入浅出 Android 安全 翻译完成!
- Tomcat 部署详解
- 多线程练习题(二)
- Ubuntu16.04配置JDK1.8.0环境。
- zip打包工具类
- 访问者模式
- 微信支付返回-1,微信填坑
- 测试地址
- The Snail
- HDU1873 看病要排队(优先队列priority_queue)
- 模板方法模式例子