All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.wildfly.clustering.context.DefaultThreadFactory Maven / Gradle / Ivy

There is a newer version: 5.0.7.Final
Show newest version
/*
 * Copyright The WildFly Authors
 * SPDX-License-Identifier: Apache-2.0
 */
package org.wildfly.clustering.context;

import java.security.AccessController;
import java.security.PrivilegedAction;
import java.util.concurrent.ThreadFactory;
import java.util.concurrent.atomic.AtomicLong;

/**
 * Default {@link ThreadFactory} implementation that applies a specific context {@link ClassLoader}.
 * @author Paul Ferraro
 */
public class DefaultThreadFactory extends ContextualThreadFactory {

	public DefaultThreadFactory(Class targetClass, ClassLoader loader) {
		this(AccessController.doPrivileged(new PrivilegedAction() {
			@Override
			public ThreadGroup run() {
				return new ThreadGroup(targetClass.getSimpleName());
			}
		}), loader);
	}

	public DefaultThreadFactory(ThreadGroup group, ClassLoader loader) {
		this(new ThreadGroupThreadFactory(group), loader);
	}

	public DefaultThreadFactory(ThreadFactory factory, ClassLoader loader) {
		super(factory, loader, ContextClassLoaderReference.INSTANCE);
	}

	private static class ThreadGroupThreadFactory implements ThreadFactory {
		private final AtomicLong index = new AtomicLong();
		private final ThreadGroup group;

		ThreadGroupThreadFactory(ThreadGroup group) {
			this.group = group;
		}

		@Override
		public Thread newThread(Runnable task) {
			ThreadGroup group = this.group;
			String name = String.format("%s - %d", this.group.getName(), this.index.incrementAndGet());
			return AccessController.doPrivileged(new PrivilegedAction<>() {
				@Override
				public Thread run() {
					return new Thread(group, task, name);
				}
			});
		}
	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy