diff options
| author | Luck <git@lucko.me> | 2018-06-06 15:39:16 +0100 |
|---|---|---|
| committer | Luck <git@lucko.me> | 2018-06-06 15:39:16 +0100 |
| commit | 7d6808cbcfbb0f61f93e536d36968eeda5bd302c (patch) | |
| tree | 3271db1ffa6e4d6c1fa5ea4ccc1335b1ac746f46 /spark-common/src/main/java/me/lucko/spark/profiler/SamplerBuilder.java | |
| parent | 38f0c12483e6eda79ca36dc829ef678a736d2cef (diff) | |
| download | spark-7d6808cbcfbb0f61f93e536d36968eeda5bd302c.tar.gz spark-7d6808cbcfbb0f61f93e536d36968eeda5bd302c.tar.bz2 spark-7d6808cbcfbb0f61f93e536d36968eeda5bd302c.zip | |
Convert to Gradle
Diffstat (limited to 'spark-common/src/main/java/me/lucko/spark/profiler/SamplerBuilder.java')
| -rw-r--r-- | spark-common/src/main/java/me/lucko/spark/profiler/SamplerBuilder.java | 63 |
1 files changed, 63 insertions, 0 deletions
diff --git a/spark-common/src/main/java/me/lucko/spark/profiler/SamplerBuilder.java b/spark-common/src/main/java/me/lucko/spark/profiler/SamplerBuilder.java new file mode 100644 index 0000000..7db0515 --- /dev/null +++ b/spark-common/src/main/java/me/lucko/spark/profiler/SamplerBuilder.java @@ -0,0 +1,63 @@ +package me.lucko.spark.profiler; + +import java.util.Timer; +import java.util.concurrent.TimeUnit; + +/** + * Builds {@link Sampler} instances. + */ +public class SamplerBuilder { + + private int samplingInterval = 4; + private long timeout = -1; + private ThreadDumper threadDumper = ThreadDumper.ALL; + private ThreadGrouper threadGrouper = ThreadGrouper.BY_NAME; + + private int ticksOver = -1; + private TickCounter tickCounter = null; + + public SamplerBuilder() { + } + + public SamplerBuilder samplingInterval(int samplingInterval) { + this.samplingInterval = samplingInterval; + return this; + } + + public SamplerBuilder completeAfter(long timeout, TimeUnit unit) { + if (timeout <= 0) { + throw new IllegalArgumentException("timeout > 0"); + } + this.timeout = System.currentTimeMillis() + unit.toMillis(timeout); + return this; + } + + public SamplerBuilder threadDumper(ThreadDumper threadDumper) { + this.threadDumper = threadDumper; + return this; + } + + public SamplerBuilder threadGrouper(ThreadGrouper threadGrouper) { + this.threadGrouper = threadGrouper; + return this; + } + + public SamplerBuilder ticksOver(int ticksOver, TickCounter tickCounter) { + this.ticksOver = ticksOver; + this.tickCounter = tickCounter; + return this; + } + + public Sampler start(Timer samplingThread) { + Sampler sampler; + if (this.ticksOver != -1 && this.tickCounter != null) { + sampler = new Sampler(this.samplingInterval, this.threadDumper, this.threadGrouper, this.timeout, this.tickCounter, this.ticksOver); + } else { + sampler = new Sampler(this.samplingInterval, this.threadDumper, this.threadGrouper, this.timeout); + } + + sampler.start(samplingThread); + return sampler; + } + +} |
