01编写10个线程,第一个线程从1加到10,第二个线程从11加20…第十个线程从91加到100,最后再把10个线程结果相加(递归算法)。
要求很明了:就是要求10个线程,每个线程执行加操作,然后顺序执行!这里我采用的方法是递归算法来解决,在run方法结束的时候,新建线程然后继续调用run方法,以此类推,保证了顺序性,也保证了相加正确的需求!
//01编写10个线程,第一个线程从1加到10,第二个线程从11加20…第十个线程从91加到100,最后再把10个线程结果相加。
//整体思路,定义共享资源sum,count,name,然后每个线程执行完10个数字相加就递归建立新线程
public class Test05 {
private static int count = 1;
private static int sum =0;
private static char name ='A';
private static Object ob = new Object();
public static void main(String[] args) {
new AddThread('A').start();//创建匿名线程启动
}
static class AddThread extends Thread{ //定义静态内部类继承Thread
public AddThread(char name){
super(name+""); //引用父类含参构造,用来给线程命名
}
@Override
public void run() {//重写run方法
while (true){
synchronized (ob){ //同步锁
if(count<100){ //确定当前加到100以内的位置
int partSum = 0; //用来计算每个线程的和
for(int i =1;i<=10;i++){ //每个线程需要循环10次,来进行和的计算
partSum+=count; //和count相加
count++; //count+1
}
sum = sum +partSum; //计算当前所有线程的和
name++; //给新线程的名字改变
System.out.print("线程"+getName()+"循环计算的和是:"+partSum);
System.out.println("----------所有线程之和是:"+sum);
new AddThread(name).run();//递归run方法,用来建立新线程和计算总和
}
if(count==101){
break;//当计数器到101后 跳出while循环
}
}
}
}
}
}