线程(三)__Interrupt 、setDaemon()、join
一、wait和sleep区别?
1.wait可以指定也可以不指定。sleep必须指定时间。
2.在同步中时,对cpu的执行权和锁的处理不同。它们都能将线程处于冻结状态。
wait:释放执行权,释放锁。
sleep:释放执行权,不释放锁。
二、线程的结束
1.调用该线程的stop()方法结束线程。容易导致不可预知的错误不推荐。
2.run()方法执行结束,线程正常结束,常用标志位来结束线程。
例:用标志位来结束线程
package com.test2;
class StopThread1 implements Runnable
{
private boolean flag=true;
public void run()
{
while(flag)
{
System.out.println(Thread.currentThread().getName()+"....");
}
} public void setFlag()
{
flag=false;
} } public class Demo2 {
public static void main(String[] args)
{
StopThread1 st=new StopThread1(); Thread t1=new Thread (st); t1.start();
int num=1;
for(;;)
{
if(++num==10)
{
st.setFlag();
break;
}
System.out.println("main"+num);
}
System.out.println("over");
}
}
问题:在上面代码加入wait()方法后,将线程处于冻结状态无法读取标记。如何结束呢?—可以使用interrupt
package com.test2;
class StopThread1 implements Runnable
{
private boolean flag=true;
public synchronized void run()
{
while(flag)
{
try {
wait();
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println(Thread.currentThread().getName()+"....");
}
} public void setFlag()
{
flag=false;
} } public class Demo2 {
public static void main(String[] args)
{
StopThread1 st=new StopThread1();
Thread t1=new Thread (st);
t1.start();
int num=1;
for(;;)
{
if(++num==10)
{
st.setFlag();
break;
}
System.out.println("main"+num);
}
System.out.println("over");
}
}
3.使用interrupt来中断线程(其实是清除wait sleep中断状态)。
* Interrupt //可以将线程从冻结状态强制恢复到运行状态中来,让cpu具备执行资格。
* 但是强制动作会发生中断异常,记得要处理,(可在异常处理中设置标志),那么再次判断标志后就可以结束线程。
package com.test2;
class StopThread1 implements Runnable
{
private boolean flag=true;
public synchronized void run()
{
while(flag)
{
try {
wait();
} catch (InterruptedException e) {
e.printStackTrace(); }
System.out.println(Thread.currentThread().getName()+"....");
}
} public void setFlag()
{
flag=false;
} } public class Demo2 {
public static void main(String[] args)
{
StopThread1 st=new StopThread1(); Thread t1=new Thread (st);
Thread t2=new Thread (st);
t1.start();
t2.start();
int num=1;
for(;;)
{
if(++num==10)
{
st.setFlag();
t1.interrupt();
break;
}
System.out.println("main"+num);
}
System.out.println("over");
}
}
三、守护线程setDaemon()、join线程
1.当前台线程结束后,后台线程就会自动结束。
记住要在线程开启之前设置守护线程,不然会报错。
package com.test2;
class StopThread1 implements Runnable
{
private boolean flag=true;
public synchronized void run()
{
while(flag)
{
try {
wait();
} catch (InterruptedException e) {
e.printStackTrace();
flag=false;
}
System.out.println(Thread.currentThread().getName()+"....");
}
} } public class Demo2 {
public static void main(String[] args)
{
StopThread1 st=new StopThread1(); Thread t1=new Thread (st);
Thread t2=new Thread (st);
t1.start();
t2.setDaemon(true);
t2.start();
int num=1;
for(;;)
{
if(++num==10)
{
t1.interrupt();
break;
}
System.out.println("main"+num);
}
System.out.println("over");
}
}
2.join方法让一个现场当代另一个线程完成的方法——join()方法。当在某个程序执行流中调用其他线程的join方法时,
调用线程将被阻塞,知道join方法加入的join线程执行完为止。join方法适合将打的问题划分为小的问题,每个小问题分配
一个线程,小线程执行完后再调用主线程进一步处理。
3.toString()方法,返回该线程的字符串表现形式,包括线程名称、优先级和线程组。
4.yield()暂停当前正在执行的线程对象,并执行其他线程,注意它只是释放执行权,再次和其他线程抢夺线程。
典型面试题:
new Thread(new Runnable() { //用匿名内部类创建线程
@Override
public void run() //父类线程任务
{
System.out.println("runnable run");
}
})
{public void run() //子类方法
{
System.out.println("subThread run"); //子类方法将父类方法覆盖 所以输出subThread run
} }.start();
线程(三)__Interrupt 、setDaemon()、join的更多相关文章
- python笔记9-多线程Threading之阻塞(join)和守护线程(setDaemon)
python笔记9-多线程Threading之阻塞(join)和守护线程(setDaemon) 前言 今天小编YOYO请xiaoming和xiaowang吃火锅,吃完火锅的时候会有以下三种场景: - ...
- java 笔记(5) —— 线程,yield,join
一.线程各个状态与转换: 新建状态:用new语句创建的线程对象处于新建状态,此时它和其它的java对象一样,仅仅在堆中被分配了内存 .就绪状态:当一个线程创建了以后,其他的线程调用了它的start() ...
- C#中的线程三 (结合ProgressBar学习Control.BeginInvoke)
C#中的线程三(结合ProgressBar学习Control.BeginInvoke) 本篇继上篇转载的关于Control.BeginInvoke的论述之后,再结合一个实例来说明Cotrol.Begi ...
- Java线程中yield与join方法的区别
长期以来,多线程问题颇为受到面试官的青睐.虽然我个人认为我们当中很少有人能真正获得机会开发复杂的多线程应用(在过去的七年中,我得到了一个机会),但是理解多线程对增加你的信心很有用.之前,我讨论了一个w ...
- 指定线程执行的顺序---join()
线程T1,T2,T3分别启动,如何让其执行顺序变为T3>T2>T1: 线程1: package test6; public class Thread1 extends Thread{ pr ...
- spark三种连接Join
本文主要介绍spark join相关操作. 讲述spark连接相关的三个方法join,left-outer-join,right-outer-join,在这之前,我们用hiveSQL先跑出了结果以方便 ...
- Java并发编程的艺术笔记(三)——Thread.join()
t.join()方法只会使主线程进入等待池并等待t线程执行完毕后才会被唤醒.并不影响同一时刻处在运行状态的其他线程.它能够使得t.join()中的t优先执行,当t执行完后才会执行其他线程.能够使得线程 ...
- C# Thread.Join的报错情形——论执行完的线程能够成功执行Join吗
结论: 能, 执行完的线程调用Join不会抛出错误. Thread.Join()是什么? Join()函数用于阻塞地等待线程结束, 其行为是在线程A中调用了线程B的Join()后, 线程A将一直阻塞在 ...
- java 多线程 Thread.join子线程结束父线程再运行;join(long):等待超时毫秒数
Join的使用 目的:当子线程运行结束后,父线程才能再继续运行 /** * @ClassName ThreadJoinExample * @projectName: object1 * @author ...
- C#中的线程(三) 使用多线程
第三部分:使用多线程 1. 单元模式和Windows Forms 单元模式线程是一个自动线程安全机制, 非常贴近于COM——Microsoft的遗留下的组件对象模型.尽管.NET最大地放弃摆脱了遗留 ...
随机推荐
- 查看Query Plan
在执行一个查询语句时,查询优化器编译查询语句,产生一个足够好的Compiled Plan,将其缓存到plan cache中.Compiled plan是基于batch的,如果一个batch含有多个qu ...
- 注意HTML的语言编码charset
注意HTML的语言编码的重要性 目录 charset编码重要性 charset在html什么地方 charset标签 编码种类 charset utf-8介绍 charset GB2312介绍 推荐网 ...
- WebStorm 9 自动编译 LESS 产出 CSS 和 source maps
1.双击桌面Chrome图标,打开Chrome,按键盘“F12”键,打开开发工具界面,点击其右上角的“设置”按钮,勾选“Enable JavaScript source maps” 及“Enable ...
- selenium-webdriver(python) (十四) -- webdriver原理
之前看乙醇视频中提到,selenium 的ruby 实现有一个小后门,在代码中加上$DEBUG=1 ,再运行脚本的过程中,就可以看到客户端请求的信息与服务器端返回的数据:觉得这个功能很强大,可以帮助理 ...
- 谈谈Java程序员进阶的那些知识和方向
谈谈Java程序员进阶的那些知识和方向 记得前段时间看过一篇文章谈到一种程序员叫野生程序员,战斗力极强,可以搞定一切问题,但是通常看问题抓不到本质,或者说是google/baidu/stackover ...
- 生成二维码的方法,基于zxing
现在生活中常用了一些二维码,这些在现实生活中已经非常密切了,那么怎么使用java来产生一个二维码呢? 下面给出代码 首先给出一个工具类,这里包含了生成二维码的图片对象,保存到流中,或者文件中: pac ...
- 【Android】使用属性动画碰到的困惑及讲解
属性动画的教程网上已经特别多了,本篇也不打算再去各种详解知识点,主要就是记录题主学习属性动画时的碰到的一些困惑,以及后来自己的理解.如果有人也碰到相似的问题,正好可以一起讨论下. 概要 本篇主要涉及的 ...
- jQuery1.9及其以上版本中动态元素on绑定事件无效解决方案
jQuery 1.9/2.0/2.1及其以上版本无法使用live函数了,然而jQuery 1.9及其以上版本提供了on函数来代替.本文讲解了jQuery on函数的使用方法,以及在使用jQuery函数 ...
- 相关子查询【SQL Server】
查询book表中大于该类图书价格平均值的图书信息 先将第一条记录的类编号的值为2代入子查询中,子查询为 select avg(price) from book b where b.id=2 则得到类编 ...
- 【转】nginx+iis实现负载均衡
最近在研究分布式系统架构方面的知识,包括负载均衡,数据库读写分离,分布式缓存redis等.本篇先从负载均衡服务架构入手,关于负载均衡百度百科的定义如下:负载均衡,英文名称为Load Balance,其 ...