首页 > 编程语言 > 详细

多线程入门-第三章-线程的调度与控制之优先级

时间:2017-04-25 14:21:36      阅读:140      评论:0      收藏:0      [点我收藏+]

包括内容:优先级、sleep、yield、join

通常计算机只有一个cpu,cpu在某一时刻只能执行一条指令,线程只有得到CPU时间片,才能执行指令。在单cpu的机器上线程表示并行运行的,只有多个CPU上线程才可以并行运行。JVM要负责线程的调度,取得CPU的使用权。目前有两种调度模型:分时调度模型和抢占式调度模型,Java使用抢占式调度模型。

分时调度模型:所有线程轮流使用CPU的使用权,平均分配每个线程占用cpu的时间片;

抢占式调度模型:优先让优先级高的线程使用cpu,如果线程的优先级相同,那么会随机选择一个,优先级高的线程获取的cpu时间片相对多一些。

线程优先级:一般分三种,最高(MAX_PRIORITY)、最低MIN_PRIORITY、标准NORM_PRIORITY

 

/*
    线程优先级:1-10,最低1,最高10,默认5
*/
public class ThreadTest03 
{
    public static void main(String[] args) 
    {
        //当前线程
        Thread t = Thread.currentThread();        //t保存的内存地址指向的线程是“主线程对象”

        //获取线程名称
        System.out.println(t.getName());

        Thread t2 = new Thread(new Processor());
        //线程起名
        t2.setName("t2");
        //更改线程优先级
        t2.setPriority(10);
        t2.start();
    }
}

class Processor implements Runnable
{
    public void run(){
        Thread t = Thread.currentThread();        //t保存的内存地址指向的线程是“t2线程对象”
        System.out.println(t.getName());
    }
}

 

多线程入门-第三章-线程的调度与控制之优先级

原文:http://www.cnblogs.com/bookwed/p/6761734.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!