多线程入门-第三章-线程的调度与控制之优先级
2017-04-25 13:59
337 查看
包括内容:优先级、sleep、yield、join
通常计算机只有一个cpu,cpu在某一时刻只能执行一条指令,线程只有得到CPU时间片,才能执行指令。在单cpu的机器上线程表示并行运行的,只有多个CPU上线程才可以并行运行。JVM要负责线程的调度,取得CPU的使用权。目前有两种调度模型:分时调度模型和抢占式调度模型,Java使用抢占式调度模型。
分时调度模型:所有线程轮流使用CPU的使用权,平均分配每个线程占用cpu的时间片;
抢占式调度模型:优先让优先级高的线程使用cpu,如果线程的优先级相同,那么会随机选择一个,优先级高的线程获取的cpu时间片相对多一些。
线程优先级:一般分三种,最高(MAX_PRIORITY)、最低
通常计算机只有一个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()); } }
相关文章推荐
- 多线程入门-第六章-线程的调度与控制之join
- 多线程入门-第五章-线程的调度与控制之yield
- 多线程入门-第四章-线程的调度与控制之sleep
- 多线程__【Thread类的方法--线程的调度与控制】
- 多线程入门教程(三)线程控制
- Java多线程-线程的调度(优先级)
- java多线程(16)--线程控制之线程优先级
- 多线程入门教程二:线程控制
- [疯狂Java]多线程:线程控制(join、daemon、sleep、yield、优先级)
- Java多线程-线程的调度(优先级)
- 多线程学习(五)线程的调度-休眠&优先级
- 多线程(三)线程控制之线程优先级
- Linux入门:多线程编程之线程控制
- java 多线程(2) 线程的调度和优先级 / sleep() / interrupt() 打断join() / yield() / setPriority()
- Java多线程:线程的调度-优先级
- Java多线程-线程的调度(优先级)
- Java多线程 -- 线程的调度优先级
- 多线程入门教程(三)线程控制
- 多线程---使用ManualResetEvent来控制线程间的同步(实现了消费者和生产者模式)
- 【转】Linux下的C编程入门之“线程”控制与“线程”通信编程