Main.java Source code

Java tutorial

Introduction

Here is the source code for Main.java

Source

//package com.java2s;
/**
 * Copyright 2008, David Robert Nadeau, NadeauSoftware.com
 *
 * This file is free software: you can redistribute it and/or modify
 * it under the terms of the GNU Lesser General Public License as
 * published by the Free Software Foundation, either version 2 of
 * the License, or (at your option) any later version.
 *
 * This file is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
 * License along with this file.  If not, see
 * <a href="http://www.gnu.org/licenses">GNU Licenses</a>.
 */

import java.lang.management.*;

public class Main {
    /**
     * The root thread group saved on the first search for it.
     * The root group doesn't change for the life of the JVM,
     * so once found there is no need to find it again.
     */
    private static ThreadGroup rootThreadGroup = null;

    /**
     * Get a list of all thread info objects.  Since there is
     * always at least one thread running, there is always at
     * least one thread info object.  This method never returns
     * a null or empty array.
     *
     * @return      an array of thread infos
     */
    public static ThreadInfo[] getAllThreadInfos() {
        final ThreadMXBean thbean = ManagementFactory.getThreadMXBean();
        final long[] ids = thbean.getAllThreadIds();

        // Get thread info with lock info, when available.
        ThreadInfo[] infos;
        if (!thbean.isObjectMonitorUsageSupported() || !thbean.isSynchronizerUsageSupported())
            infos = thbean.getThreadInfo(ids);
        else
            infos = thbean.getThreadInfo(ids, true, true);

        // Clean nulls from array if threads have died.
        final ThreadInfo[] notNulls = new ThreadInfo[infos.length];
        int nNotNulls = 0;
        for (ThreadInfo info : infos)
            if (info != null)
                notNulls[nNotNulls++] = info;
        if (nNotNulls == infos.length)
            return infos; // Original had no nulls
        return java.util.Arrays.copyOf(notNulls, nNotNulls);
    }

    /**
     * Get the thread info for the thread with the given name.
     * A null is returned if no such thread info is found.
     * If more than one thread has the same name, the thread
     * info for the first one found is returned.
     *
     * @param   name   the thread name to search for
     * @return      the thread info, or null if not found
     * @throws   NullPointerException
     *          if the name is null
     */
    public static ThreadInfo getThreadInfo(final String name) {
        if (name == null)
            throw new NullPointerException("Null name");

        final Thread[] threads = getAllThreads();
        for (Thread thread : threads)
            if (thread.getName().equals(name))
                return getThreadInfo(thread.getId());
        return null;
    }

    /**
     * Get the thread info for the thread with the given ID.
     * A null is returned if no such thread info is found.
     *
     * @param   id   the thread ID to search for
     * @return      the thread info, or null if not found
     * @throws   IllegalArgumentException
     *         if id <= 0
     */
    public static ThreadInfo getThreadInfo(final long id) {
        final ThreadMXBean thbean = ManagementFactory.getThreadMXBean();

        // Get thread info with lock info, when available.
        if (!thbean.isObjectMonitorUsageSupported() || !thbean.isSynchronizerUsageSupported())
            return thbean.getThreadInfo(id);

        final ThreadInfo[] infos = thbean.getThreadInfo(new long[] { id }, true, true);
        if (infos.length == 0)
            return null;
        return infos[0];
    }

    /**
     * Get the thread info for the given thread.  A null is
     * returned if the thread info cannot be found.
     *
     * @param   thread   the thread to search for
     * @return      the thread info, or null if not found
     * @throws   NullPointerException
     *          if thread is null
     */
    public static ThreadInfo getThreadInfo(final Thread thread) {
        if (thread == null)
            throw new NullPointerException("Null thread");
        return getThreadInfo(thread.getId());
    }

    /**
     * Get a list of all threads.  Since there is always at
     * least one thread, this method never returns null or
     * an empty array.
     *
     * @return      an array of threads
     */
    public static Thread[] getAllThreads() {
        final ThreadGroup root = getRootThreadGroup();
        final ThreadMXBean thbean = ManagementFactory.getThreadMXBean();
        int nAlloc = thbean.getThreadCount();
        int n = 0;
        Thread[] threads = null;
        do {
            nAlloc *= 2;
            threads = new Thread[nAlloc];
            n = root.enumerate(threads, true);
        } while (n == nAlloc);
        return java.util.Arrays.copyOf(threads, n);
    }

    /**
     * Get a list of all threads with a given thread state.
     * Thread states are defined in the Thread.State enum for
     * the Thread class.  Principal thread states include
     * RUNNABLE, WAITING, TIMED_WAITING, and BLOCKED.  An
     * empty array is returned if there are no threads in
     * the chosen state.
     *
     * @param   state   the state to look for
     * @return      an array of threads in that state
     */
    public static Thread[] getAllThreads(final Thread.State state) {
        final Thread[] allThreads = getAllThreads();
        final Thread[] found = new Thread[allThreads.length];
        int nFound = 0;
        for (Thread thread : allThreads)
            if (thread.getState() == state)
                found[nFound++] = thread;
        return java.util.Arrays.copyOf(found, nFound);
    }

    /**
     * Get the root thread group in the thread group tree.
     * Since there is always a root thread group, this
     * method never returns null.
     *
     * @return      the root thread group
     */
    public static ThreadGroup getRootThreadGroup() {
        if (rootThreadGroup != null)
            return rootThreadGroup;

        ThreadGroup tg = Thread.currentThread().getThreadGroup();
        ThreadGroup ptg;
        while ((ptg = tg.getParent()) != null)
            tg = ptg;
        rootThreadGroup = tg;
        return tg;
    }
}