Google面试题(java)—有四个线程1、2、3、4。线程1的功能就是输出1,线程2的功能就是输出2,以此类推.........现在有四个文件ABCD

43 篇文章 0 订阅
27 篇文章 0 订阅

转自:http://blog.csdn.net/b275518834/article/details/8750142


import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;

public class CallThread {
	private static class MyRunable implements Runnable {
		int index = 0;
		int max = 4 * 2;
		HashMap<Integer, List<Integer>> map = new HashMap<Integer, List<Integer>>();
		{
			for (int i = 0; i < 4; i++) {
				map.put(i, new ArrayList<Integer>());
			}
		}
		boolean isRunning = true;

		public synchronized void run() {
			while (true) {
				int name = Integer.valueOf(Thread.currentThread().getName());
				while (index % 4 != name) {
					try {
						this.wait();
					} catch (InterruptedException e) {
						// TODO Auto-generated catch block
						e.printStackTrace();
					}
					if (!isRunning) {
						return;
					}
				}
				try {
					Thread.sleep(1000);
				} catch (InterruptedException e) {
				}
				for (int i = 0, arrIndex = index; i < 4; i++ ) {
					try {
						if (arrIndex-- < 0) {
							break;
						}
						List<Integer> list = map.get(i);
						if (list.size() < max) {
							list.add(name + 1);
						}
					} catch (Exception e) {
					}
				}
				System.err.println("A:" + map.get(0));
				System.err.println("B:" + map.get(1));
				System.err.println("C:" + map.get(2));
				System.err.println("D:" + map.get(3));
				System.err.println("-----------------------");

				if (map.get(map.size()-1).size() == max) {
					isRunning = false;
					this.notifyAll();
					return;
				} else {
					index++;
				}
				this.notifyAll();
			}
		}

	}

	public static void main(String[] args) throws InterruptedException {
		Runnable runable = new MyRunable();
		for (int i = 0; i < 4; i++) {
			Thread t = new Thread(runable);
			t.setName(String.valueOf(i));
			t.start();
		}
	}
}



C++ 不过不完整

 1 #include <iostream>
 2 #include <stdlib.h>
 3 #include <pthread.h>
 4 using namespace std;
 5 
 6 pthread_mutex_t myloack=PTHREAD_MUTEX_INITIALIZER;
 7 pthread_cond_t mycond=PTHREAD_COND_INITIALIZER;
 8 int n=0;
 9 void *ThreadFunc(void *arg)
10 {
11     int num=(int )arg;
12     for (int i = 0; i < 10; ++i)
13     {
14         pthread_mutex_lock(&myloack);
15         while (n!=num)//1号线程第一次执行时直接跳过
16             pthread_cond_wait(&mycond,&myloack);//因为多个线程共用一个条件变量,所以在田间变量被signal后,需要用while来确定是否本线程获得执行权
17 
18         if (num==0)
19             cout<<"1";
20         else if(num==1)
21             cout<<"2";
22         else if(num==2)
23             cout<<"3";
24         else 
25             cout<<"4"<<endl;
26         n=(n+1)%4;
27         pthread_mutex_unlock(&myloack);
28         pthread_cond_broadcast(&mycond);
29     }
30     return (void *)0;
31 }
32 
33 int  main(int argc, char const *argv[])
34 {
35 
36     pthread_t id[4];
37     for (int i = 0; i < 4; ++i)
38     {
39         int err=pthread_create(&id[i],NULL,ThreadFunc,(void *)i);
40         if (err!=0)
41         {
42             cout<<"create err:"<<endl;
43             exit(-1);
44         }
45 
46     }
47 
48     for (int i = 0; i < 4; ++i)
49     {
50         int ret=pthread_join(id[i],NULL);
51         if (ret!=0)
52         {
53             cout<<"join err:"<<endl;
54             exit(-1);
55         }
56     }
57     return 0;
58 }


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值