利用多线程求解某范围质数,每个线程负责 1000范围:线程1找1-1000;线程 2 找 1001-2000;线程 3 找 2001-3000。编程程序将每个线程找到的素数及时打印。
线程池和匿名类
public static void main(String[] args) {
//.利用多线程求解某范围质数,每个线程负责 1000范围:
// 线程1找1-1000;线程 2 找 1001-2000;
// 线程 3 找 2001-3000。
// 编程程序将每个线程找到的素数及时打印。
ExecutorService es = Executors.newFixedThreadPool(3);
es.submit(new Runnable() {
@Override
public void run() {
//线程1找1-1000质数
for (int i = 2; i <= 1000; i++) {
if (isZS(i)){
System.out.println("i = " + i);
}
}
}
});
es.submit(new Runnable() {
@Override
public void run() {
//线程1找1-1000质数
for (int i = 1001; i <= 2000; i++) {
if (isZS(i)){
System.out.println("i = " + i);
}
}
}
});
es.submit(new Runnable() {
@Override
public void run() {
//线程1找1-1000质数
for (int i = 2001; i <= 3000; i++) {
if (isZS(i)){
System.out.println("i = " + i);
}
}
}
});
es.shutdown();
}
public static boolean isZS(int number){
for (int i = 2; i < number; i++) {
if (number % i == 0){
return false;
}
}
return true;
}
打印结果:
i = 2
i = 3
i = 5
i = 7
i = 11
i = 263
i = 269
i = 271
i = 1049
i = 2063
i = 401
i = 2069…交替打印