一、概述

  到第八节,就把多线程基本的概念都说完了。把前面的所有文章加连接在此:

  Java多线程——<一>概述、定义任务

  Java多线程——<二>将任务交给线程,线程声明及启动

  Java多线程——<三>简单的线程执行:Executor

  Java多线程——<四>让线程有返回值

  Java多线程——<五>后台线程(daemon)

  Java多线程——<六>更方便的线程

  Java多线程——<七>多线程的异常捕捉

  均是个人理解和总结,代码均来自《thinking in java》,有问题欢迎大家指正。

二、多线程的其他概念

  1.休眠

  休眠,其实就是让线程暂停一段时间,也就是阻塞一段时间。例如:每个打印之后,每个线程都要睡眠(即阻塞),这使得线程调度器可以切换到另一个线程,进而驱动另一个任务。这导致了线程在执行顺序上得到了保证,可以通过查看打印输出消息证实这一点。

public class TaskSleepingTask extends Task{
@Override
public void run() {
try{
while(countDown-- > 0){
System.out.println(status());
/*
* 每个打印之后,每个线程都要睡眠(即阻塞),这使得线程调度器可以切换到另一个线程,进而驱动另一个任务
*/
TimeUnit.MICROSECONDS.sleep(100000);
}
/*
* 因为异常不能跨线程传回给main,所以你必须在线程里处理该异常
*/
}catch(InterruptedException e){
System.out.println();
}
}
public static void main(String[] args){
ExecutorService exec = Executors.newCachedThreadPool();
for(int i = 0 ; i < 5 ; i++){
exec.execute(new TaskSleepingTask());
}
exec.shutdown();
}
}

  但是,这不代表你就可以通过休眠的方式来保证任务的执行顺序(顺序行为依赖于底层的线程机制,这种机制在不同的操作系统之间是有差异的

  要想控制顺序的解决办法:1、同步控制,2、协作线程(以后再做序数)

  2.优先级

  优先级代表了该线程的重要性,线程调度器将倾向于让优先级高的线程先执行(但这不意味着优先权较低的线程将得不到执行,即优先权不会导致死锁)。优先级较低的线程仅仅是执行频率较低,在绝大多数时间里,所有线程都应该以默认优先级运行,试图操纵线程优先级通常是一种错误。

  通过Thread.currentThread()方法来获得对驱动该任务的Thread对象的引用,然后设置线程优先级。

public class TaskPriority implements Runnable{
private int countDown = 5;
/*
* 变量d用来确保不进行任何编译器优化
*/
@SuppressWarnings("unused")
private volatile double d;//no optimization
private int priority;
public TaskPriority(int priority){
this.priority = priority;
}
/*
* 打印线程的名称、线程的优先级以及线程所属的“线程组”
*在线程内部,通过调用Thread.currentThread()来获得对驱动该任务的Thread对象的引用
*/
public String toString(){
return Thread.currentThread()+":"+countDown;
}
@Override
public void run() {
/*
* 优先级应该在run的开头部分设定,在构造器中设置他们不会有任何好处,因为Executor在此刻还没有开始执行任务
*/
Thread.currentThread().setPriority(priority);
/*
* 执行了10000次浮点运算,数学 运算是可以中断的,这里运算时间足够长,
* 因此线程调度机制才来得及介入,交换任务并关注优先级,使得最高优先级的线程被优先选择
*/
while(true){
for(int i = 1 ;i < 10000;i++){
d+=(Math.PI + Math.E)/(double)i;
if(i%1000==0)
Thread.yield();
System.out.println(this);
if(--countDown == 0 )
return;
}
}
}
public static void main(String[] args){
ExecutorService exec = Executors.newCachedThreadPool();
for(int i = 0 ; i < 5;i++){
exec.execute(new TaskPriority(Thread.MIN_PRIORITY));//
}
exec.execute(new TaskPriority(Thread.MAX_PRIORITY));//
exec.shutdown();
}
}

  尽管jdk有10个优先级,但是它与多数操作系统都不能映射得很好(windows7个,solaris2个),唯一可移植的方法是当调整优先级的时候,只试用MAX_PRIORITY/NORM_PRIORITY/MIN_PRIORITY三种声明

  3.让步

  在你已经确认完成了在run方法的循环的一次迭代过程中所需的工作,就可以给线程调度机制一个暗示:你的工作已经做的差不多了,可以让别的线程试用cpu了。(让相同优先级的其他线程可以运行)。

  java提供了调用yield()方法来实现。过这只是暗示没有任何机制保证它会被采纳,所以不能依赖该方法。如上例。

Java多线程——<八>多线程其他概念的更多相关文章

  1. java 并发多线程 锁的分类概念介绍 多线程下篇(二)

    接下来对锁的概念再次进行深入的介绍 之前反复的提到锁,通常的理解就是,锁---互斥---同步---阻塞 其实这是常用的独占锁(排它锁)的概念,也是一种简单粗暴的解决方案 抗战电影中,经常出现为了阻止日 ...

  2. java 并发多线程显式锁概念简介 什么是显式锁 多线程下篇(一)

    目前对于同步,仅仅介绍了一个关键字synchronized,可以用于保证线程同步的原子性.可见性.有序性 对于synchronized关键字,对于静态方法默认是以该类的class对象作为锁,对于实例方 ...

  3. Java基础学习(八) - 多线程

    理解线程 进程是指一个内存中运行的应用程序,系统运行一个程序即是一个进程从创建,运行,结束的过程. 线程是进程中的一个执行单元,负责当前进程中程序的执行,一个进程中至少有一个线程. 多线程的特点是并发 ...

  4. Java线程与多线程教程

    本文由 ImportNew - liken 翻译自 Journaldev.   Java线程是执行某些任务的轻量级进程.Java通过Thread类提供多线程支持,应用可以创建并发执行的多个线程. 应用 ...

  5. core java 10~12(多线程 & I/O & Network网络编程)

    MODULE 10 Threads 多线程-------------------------------- 进程: 计算机在运行过程中的任务单元,CPU在一个时间点上只能执行一个进程,但在一个时间段上 ...

  6. Java中的多线程Demo

    一.关于Java多线程中的一些概念 1.1 线程基本概念 从JDK1.5开始,Java提供了3中方式来创建.启动多线程: 方式一(不推荐).通过继承Thread类来创建线程类,重写run()方法作为线 ...

  7. Java 中传统多线程

    目录 Java 中传统多线程 线程初识 线程的概念 实现线程 线程的生命周期 常用API 线程同步 多线程共享数据的问题 线程同步及实现机制 线程间通讯 线程间通讯模型 线程中通讯的实现 @(目录) ...

  8. Java基础之多线程框架

    一.进程与线程的区别 1.定义: 进程是具有一定独立功能的程序关于某个数据集合上的一次运行活动,进程是系统进行资源分配和调度的一个独立单位. 线程是进程的一个实体,是CPU调度和分派的基本单位,它是比 ...

  9. Java基础之多线程没那么复杂!

    多线程的引入 1.什么是多线程 线程是程序执行的一条路径,一个进程中可以包含多条线程;多线程并发执行可以提高程序的效率</br> 2.进程和线程之间的关系 操作系统可以同时执行多个任务,每 ...

随机推荐

  1. mysql给root开启远程访问权限,修改root密码

    1.MySql-Server 出于安全方面考虑只允许本机(localhost, 127.0.0.1)来连接访问. 这对于 Web-Server 与 MySql-Server 都在同一台服务器上的网站架 ...

  2. MapReduce框架Partitioner分区方法

    前言:对于二次排序相信大家也是似懂非懂,我也是一样,对其中的很多方法都不理解诶,所有只有暂时放在一边,当你接触到其他的函数,你知道的越多时你对二次排序的理解也就更深入了,同时建议大家对wordcoun ...

  3. 三种找回 linux root密码

    找回 linux root密码的三种方法 第1种方法: 1.在系统进入单用户状态,直接用passwd root去更改2.用安装光盘引导系统,进行linux rescue状态,将原来/分区挂接上来,作法 ...

  4. activity切换动画特效

    效果图: 结构图: 测试代码: 布局: <?xml version="1.0" encoding="utf-8"?> <LinearLayou ...

  5. 苹果Mac OS系统shell命令大全介绍

    基本命令 1.列出文件 ls 参数 目录名        例: 看看驱动目录下有什么:ls /System/Library/Extensions 参数 -w 显示中文,-l 详细信息, -a 包括隐藏 ...

  6. 批量kill进程

    ps -e | grep java |awk '{print $1}'|xargs kill -9

  7. Python学习教程(learning Python)--3.3.1 Python下的布尔表达式

    简单的说就是if要判断condition是真是假,Python和C语言一样非0即真,所以如果if的condition是布尔表达式我们可以用True或者非0数(不可是浮点数)表示真,用False或者0表 ...

  8. 机器学习相关——协同过滤

    在现今的推荐技术和算法中,最被大家广泛认可和采用的就是基于协同过滤的推荐方法.本文将带你深入了解协同过滤的秘密.下面直接进入正题 1 什么是协同过滤 协同过滤是利用集体智慧的一个典型方法.要理解什么是 ...

  9. Node.js:util.inherits 面向对象特性【原型】

    /** * Created by Administrator on 2014/9/4. */ var util = require('util'); function Base() { this.na ...

  10. TextSwitcher,译为文字转换器控件

    ViewSwitcher仅仅包含子类型TextView.TextSwitcher被用来使屏幕上的label产生动画效果.每当setText(CharSequence)被调用时,TextSwitcher ...