com.icesoft.util.ThreadFactory.java Source code

Java tutorial

Introduction

Here is the source code for com.icesoft.util.ThreadFactory.java

Source

/*
 * Version: MPL 1.1/GPL 2.0/LGPL 2.1
 *
 * "The contents of this file are subject to the Mozilla Public License
 * Version 1.1 (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.mozilla.org/MPL/
 *
 * Software distributed under the License is distributed on an "AS IS"
 * basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See the
 * License for the specific language governing rights and limitations under
 * the License.
 *
 * The Original Code is ICEfaces 1.5 open source software code, released
 * November 5, 2006. The Initial Developer of the Original Code is ICEsoft
 * Technologies Canada, Corp. Portions created by ICEsoft are Copyright (C)
 * 2004-2006 ICEsoft Technologies Canada, Corp. All Rights Reserved.
 *
 * Contributor(s): _____________________.
 *
 * Alternatively, the contents of this file may be used under the terms of
 * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"
 * License), in which case the provisions of the LGPL License are
 * applicable instead of those above. If you wish to allow use of your
 * version of this file only under the terms of the LGPL License and not to
 * allow others to use your version of this file under the MPL, indicate
 * your decision by deleting the provisions above and replace them with
 * the notice and other provisions required by the LGPL License. If you do
 * not delete the provisions above, a recipient may use your version of
 * this file under either the MPL or the LGPL License."
 */
package com.icesoft.util;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;

public class ThreadFactory implements edu.emory.mathcs.backport.java.util.concurrent.ThreadFactory {
    private static final Log LOG = LogFactory.getLog(ThreadFactory.class);

    private final Object lock = new Object();

    private int counter;
    private boolean daemon = true;
    private String prefix = "Thread";

    public ThreadFactory() {
        // do nothing.
    }

    /**
     * <p>
     *   Gets the prefix of the name of threads to be created through this
     *   <code>ThreadFactory</code>.
     * </p>
     *
     * @return     the prefix.
     * @see        #setPrefix(String)
     */
    public String getPrefix() {
        return prefix;
    }

    /**
     * <p>
     *   Checks if threads to be created through this <code>ThreadFactory</code>
     *   are daemon threads.
     * </p>
     *
     * @return     <code>true</code> if threads to be created are daemon
     *             threads, <code>false</code> if not.
     * @see        #setDaemon(boolean)
     */
    public boolean isDaemon() {
        return daemon;
    }

    public Thread newThread(final Runnable runnable) {
        Thread _thread;
        synchronized (lock) {
            _thread = new Thread(runnable, prefix + " [" + ++counter + "]");
        }
        _thread.setDaemon(daemon);
        try {
            /*
             * We attempt to set the context class loader because some J2EE
             * containers don't seem to set this properly, which leads to
             * important classes not being found. However, other J2EE containers
             * see this as a security violation.
             */
            _thread.setContextClassLoader(runnable.getClass().getClassLoader());
        } catch (SecurityException exception) {
            /*
             * If the current security policy does not allow this, we have to
             * hope that the appropriate class loader settings were transferred
             * to this new thread.
             */
            if (LOG.isTraceEnabled()) {
                LOG.trace("Setting the context class loader is not permitted.", exception);
            }
        }
        if (LOG.isDebugEnabled()) {
            LOG.debug("New thread: " + _thread.getName());
        }
        return _thread;
    }

    /**
     * <p>
     *   Sets if threads to be created through this <code>ThreadFactory</code>
     *   are daemon threads according to the specified <code>daemon</code>
     *   value.
     * </p>
     *
     * @param      daemon
     *                 the new daemon value.
     * @see        #isDaemon()
     */
    public void setDaemon(final boolean daemon) {
        this.daemon = daemon;
    }

    /**
     * <p>
     *   Sets the prefix of the name of threads to be created through this
     *   <code>ThreadFactory</code> to the specified <code>prefix</code>.
     * </p>
     *
     * @param      prefix
     *                 the new prefix.
     * @see        #getPrefix()
     */
    public void setPrefix(final String prefix) {
        this.prefix = prefix;
    }
}