admin管理员组

文章数量:1623796

接上一篇:Thread的SetDeamon()守护线程源代码分析(4)

我们知道线程在执行start()之后,如果没有cpu执行权的话,它是在runnable状态,而不会进入到running状态或者exception状态,而且各个线程运行的结果次数也有可能不会是一样的,这体现了多线程的不确定性,那么我们可以通过设置优先级来让线程运行的次数如自己所想随心所欲呢?

下面我们来看Thread的setPriority()方法,

 public final void setPriority(int newPriority) {
        ThreadGroup g;
        checkAccess();
        if (newPriority > MAX_PRIORITY || newPriority < MIN_PRIORITY) {
            throw new IllegalArgumentException();
        }
        if((g = getThreadGroup()) != null) {
            if (newPriority > g.getMaxPriority()) {
                newPriority = g.getMaxPriority();
            }
            setPriority0(priority = newPriority);
        }
    }

更改线程的优先级。

首先调用线程的 checkAccess 方法,且不带任何参数。这可能抛出 SecurityException

在其他情况下,线程优先级被设定为指定的 newPriority 和该线程的线程组的最大允许优先级相比较小的一个。

参数:

newPriority - 要为线程设定的优先级

抛出:

IllegalArgumentException - 如果优先级不在 MIN_PRIORITYMAX_PRIORITY 范围内。

SecurityException - 如果当前线程无法修改该线程。

以上抄自JDK1.7Api

下面我们来写下代码实现下:

public static void main(String[] args) {
		Thread t1 = new Thread(new Runnable() {
			@Override
			public void run() {
				for (int i = 0; i < 100; i++) {
					System.out.println(Thread.currentThread().getName()+"---"+i);
				}
			}
		},"myThread--01");
		//set max priority
		t1.setPriority(Thread.MAX_PRIORITY);

		Thread t2 = new Thread(new Runnable() {
			@Override
			public void run() {
				for (int i = 0; i < 100; i++) {
					System.out.println(Thread.currentThread().getName()+"---"+i);
				}

			}
		},"myThread--02");
		//set norm priority
		t2.setPriority(Thread.NORM_PRIORITY);

	Thread t3 = new Thread(new Runnable() {
		@Override
		public void run() {
			for (int i = 0; i < 100; i++) {
				System.out.println(Thread.currentThread().getName()+"---"+i);
			}
		}
	},"myThread--03");
	//set min priority == 1
		t3.setPriority(Thread.MIN_PRIORITY);

		t1.start();
		t2.start();
		t3.start();
	}

而查看结果时虽然发现myThread--01在开始出现的次数多,但是却并不如我们所理想中的那样。

本文标签: 优先级源代码threadsetPriority