Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Appearance settings

Latest commit

 

History

History
History
53 lines (38 loc) · 1.51 KB

File metadata and controls

53 lines (38 loc) · 1.51 KB
Copy raw file
Download raw file
Open symbols panel
Edit and raw actions
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
package thread.chapterFour.ThreadPoolExecutor;
import java.util.concurrent.LinkedBlockingDeque;
import java.util.concurrent.ThreadPoolExecutor;
import java.util.concurrent.TimeUnit;
public class Run {
public static void main(String[] args) throws InterruptedException {
ThreadPoolExecutor threadPoolExecutor = new ThreadPoolExecutor(2, 999, 999L, TimeUnit.SECONDS, new LinkedBlockingDeque<>());
threadPoolExecutor.execute(new Runnable() {
@Override
public void run() {
System.out.println("thread begin");
try {
Thread.sleep(4000);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println("thread end");
}
});
threadPoolExecutor.execute(new Runnable() {
@Override
public void run() {
System.out.println("thread2 begin");
try {
Thread.sleep(2000);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println("thread2 end");
}
});
// 线程池未关闭则阻塞一定时间 超过继续往下执行
threadPoolExecutor.awaitTermination(10, TimeUnit.SECONDS);
// 不接受新的任务 当前任务执行完关闭线程池
threadPoolExecutor.shutdown();
System.out.println("main thread end");
}
}
Morty Proxy This is a proxified and sanitized view of the page, visit original site.