当前位置:首页 > 开发 > 编程语言 > 多线程 > 正文

线程的调度

发表于: 2013-05-25   作者:bijian1013   来源:转载   浏览:
摘要: 1.       Java提供一个线程调度程序来监控程序中启动后进入可运行状态的所有线程。线程调度程序按照线程的优先级决定应调度哪些线程来执行。   2.       多数线程的调度是抢占式的(即我想中断程序运行就中断,不需要和将被中断的程序协商) a) 

1.       Java提供一个线程调度程序来监控程序中启动后进入可运行状态的所有线程。线程调度程序按照线程的优先级决定应调度哪些线程来执行。

 

2.       多数线程的调度是抢占式的(即我想中断程序运行就中断,不需要和将被中断的程序协商)

a)         时间片方式(time slicing

b)        非时间片方式

 

3.       下面几种情况下,当前线程会放弃CPU

a)         线程调用了yield()sleep()方法主动放弃

b)        由于当前线程进行I/O访问,外存读写,等待用户输入等操作,导致线程阻塞

c)        为等候一个条件变量,线程调用wait()方法

d)        抢先式系统下,有高优先级的线程参与调度;时间片方式下,当前时间片用完,有同优先级的线程参与调度

 

4.       Java至少有两个线程:主线程、垃圾收集线程

多线程的运行模式有协作式和抢占式。

协作式:主动让出时间片,要加sleep提高CPU利用,否则一直占用CPU

抢占式:CPU分配时间片,不加sleep会提高分配到CPU资源的机会

一般在多线程中适当sleep,哪怕很短,因为如在协作式系统中,线程不会让出CPU,如有线程是高速设备的运行,而其它设备有IO等设备的操作运行。而线程执行机会是均等的,如不加sleep,及可能的情况是:高速设备的线程独占CPU

线程的调度

  • 0

    开心

    开心

  • 0

    板砖

    板砖

  • 0

    感动

    感动

  • 0

    有用

    有用

  • 0

    疑问

    疑问

  • 0

    难过

    难过

  • 0

    无聊

    无聊

  • 0

    震惊

    震惊

编辑推荐
概述 Windows 实现了一个由优先级驱动,抢占式的调度系统,也就是最高优先级的可运行的(就绪状态下
线程的状态转换: 新建状态:new出一个线程,线程还没有开始运行,当线程处于新建状态时,程序还没
概述 Windows 实现了一个由优先级驱动,抢占式的调度系统,也就是最高优先级的可运行的(就绪状态下
1,线程的生命周期 线程从创建、运行到结束总是处于下面五个状态之一:新建状态、就绪状态、运行状态
1,线程的生命周期 线程从创建、运行到结束总是处于下面五个状态之一:新建状态、就绪状态、运行状态
1、首先简单说下java内存模型:Java中所有变量都储存在主存中,对于所有线程都是共享的(因为在同一
1、join的用法 package com.ljb.app.thread; /** * 线程调度join的使用 * @author LJB * @version 2
与线程休眠类似,线程的优先级仍然无法保障线程的执行次序。只不过,优先级高的线程获取CPU资源的概
什么是线程 什么是线程?线程与进程与有什么关系?这是一个非常抽象的问题,也是一个特别广的话题,
转自:http://www.cnblogs.com/wonderKK/archive/2012/06/10/2543999.html 线程,有时被称为轻量级
版权所有 IT知识库 CopyRight © 2009-2015 IT知识库 IT610.com , All Rights Reserved. 京ICP备09083238号