blob: 56a6cc4593c27ce86c92b5ae4a35ff6f88dc81e3 (
plain)
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
|
package me.lucko.spark.profiler;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
/**
* Function for grouping threads together
*/
@FunctionalInterface
public interface ThreadGrouper {
/**
* Gets the group for the given thread.
*
* @param threadName the name of the thread
* @return the group
*/
String getGroup(String threadName);
/**
* Implementation of {@link ThreadGrouper} that just groups by thread name.
*/
ThreadGrouper BY_NAME = new ByName();
final class ByName implements ThreadGrouper {
@Override
public String getGroup(String threadName) {
return threadName;
}
}
/**
* Implementation of {@link ThreadGrouper} that attempts to group by the name of the pool
* the thread originated from.
*/
ThreadGrouper BY_POOL = new ByPool();
final class ByPool implements ThreadGrouper {
private static final Pattern THREAD_POOL_PATTERN = Pattern.compile("^(.*)[-#] ?\\d+$");
@Override
public String getGroup(String threadName) {
Matcher matcher = THREAD_POOL_PATTERN.matcher(threadName);
if (!matcher.matches()) {
return threadName;
}
return matcher.group(1).trim() + " (Combined)";
}
}
}
|