多线程和单线程 打印数字到100000 的速度对比
生活随笔
收集整理的這篇文章主要介紹了
多线程和单线程 打印数字到100000 的速度对比
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
import java.util.concurrent.ArrayBlockingQueue;
import java.util.concurrent.Executors;
import java.util.concurrent.ThreadPoolExecutor;
import java.util.concurrent.TimeUnit;
/**
-
@author silence
-
多線程和單線程 打印數字到100000 的速度對比
//10條線程 耗時毫秒:4356tenThread(number);
*/
public class Demo2 {
public static void main(String[] args) {
//循環次數
int number = 5000000;
//單線程 耗時毫秒:3349 : 1000000
// ontThread(number);}
/**
- 多線程
- @param number 循環次數
*/
private static void tenThread(int number) {
long start = System.currentTimeMillis();
ThreadPoolExecutor thread = new ThreadPoolExecutor(
//核心線程數
10,
//最大線程數
10,
//等待時間
10,
//等待單位
TimeUnit.SECONDS,
//排隊阻塞隊列
new ArrayBlockingQueue<>(1),
//線程工廠
Executors.defaultThreadFactory(),
//拒絕策略
new ThreadPoolExecutor.AbortPolicy()
);
MyRunnable myRunnable = new MyRunnable(number);
for (int i = 0; i < 10; i++) {
thread.submit(myRunnable);
}
//結束線程池
thread.shutdown();
//一致在這里等多線程執行完畢,計算毫秒數
while (true) {
//等所有線程執行完,否則一直等
if (thread.isTerminated()) {
long end = System.currentTimeMillis();
System.out.println(“耗時毫秒:” + (end - start));
break;
}
}
}
//線程實現類
public MyRunnable() {}public MyRunnable(int number) {this.number = number;}@Overridepublic void run() {while (count < number) {
static class MyRunnable implements Runnable {
private static int count = 0;
private int number;
// System.out.print(Thread.currentThread().getName() + " = ");
System.out.println(count++);
}
}
}
}
總結
以上是生活随笔為你收集整理的多线程和单线程 打印数字到100000 的速度对比的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: bmupdate.exe是什么进程 bm
- 下一篇: 采油工计算机试题库,数字化采油工试题库.