one.nio.async.CustomThreadFactory Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of one-nio Show documentation
Show all versions of one-nio Show documentation
Unconventional Java I/O library
The newest version!
/*
* Copyright 2019 Odnoklassniki Ltd, Mail.Ru Group
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package one.nio.async;
import one.nio.os.SchedulingPolicy;
import one.nio.server.PayloadThread;
import java.util.concurrent.ForkJoinPool;
import java.util.concurrent.ForkJoinWorkerThread;
import java.util.concurrent.ThreadFactory;
import java.util.concurrent.atomic.AtomicInteger;
public class CustomThreadFactory implements ThreadFactory, ForkJoinPool.ForkJoinWorkerThreadFactory {
private final String name;
private final boolean daemon;
private final SchedulingPolicy schedulingPolicy;
private final AtomicInteger id = new AtomicInteger();
public CustomThreadFactory(String name) {
this(name, false, null);
}
public CustomThreadFactory(String name, boolean daemon) {
this(name, daemon, null);
}
public CustomThreadFactory(String name, boolean daemon, SchedulingPolicy schedulingPolicy) {
this.name = name;
this.daemon = daemon;
this.schedulingPolicy = schedulingPolicy;
}
@Override
public Thread newThread(Runnable r) {
PayloadThread thread = new PayloadThread(r, name + "-" + id.incrementAndGet());
thread.setDaemon(daemon);
thread.setSchedulingPolicy(schedulingPolicy);
return thread;
}
@Override
public ForkJoinWorkerThread newThread(ForkJoinPool pool) {
ForkJoinWorkerThread thread = new ForkJoinWorkerThread(pool) {
@Override
protected void onStart() {
super.onStart();
if (schedulingPolicy != null) {
schedulingPolicy.apply();
}
}
};
thread.setName(name + "-" + id.incrementAndGet());
return thread;
}
}