Two-phapse-Termination[A终止B线程]

一:Two-phapse-Termination的参与者
--->A线程
--->B线程

二:Two-phapse-Termination模式什么时候使用
--->当A线程需要B线程终止时

三:Two-phapse-Termination思考
       ---> 优雅的终止线程
        (1)安全地终止(安全性)==>即使收到终止请求,也不会马上结束线程,而是表示收到终止请求的标识。以对象不被损坏为前提,安全终止
        (2)一定会进行终止处理(生命性)==>当收到终止请求,会中断掉可以中断的wait,前往终止处理。异常处理要非常小心,防止抛出异常,破坏对象。
        (3)送出终止请求后,要尽快进入终止处理(响应性)==>当收到终止请求,可以中断掉Sleep,尽快终止处理

四进阶说明        
--->首先来说说java中的中断机制,Java 中断机制是一种协作机制,也就是说通过中断并不能直接终止另一个线程,而需要被中断的线程自己处理中断。当调用interrupt()方法的时候,只是设 置了要中断线程的中断状态,而此时被中断的线程的可以通过isInterrupted()或者是interrupted()方法判断当前线程的中断状态是

--->interrupte()和interrupted()和isInterrputed()方法的区别
        (1)线程对象.interrupte()是将调用该方法的对象所指的线程的中断状态修改为:【中断状态】
        (2)Thead.interrputed()是检查当前线程的中断状态,如果为中断状态,则返回true,并将中断状态清除掉。如果为非中断状态,返回false
        (3)线程对象.isInterrputed()是返回当前线程是否为中断状态,并不会修改线程的中断状态

---->wait方法被中断后,不会立马跑出InterrptedException,而是要重新获取锁定,才可抛出该异常。

--->书上一种解释:
        A线程中b.interrput()执行,B线程正处于sleep或wait状态,则会立马提前放弃休眠或等待,抛出interrputedException异常。线程的【中断状态】会立马被清除掉。
        【测试未得到印证】
-->书上另一种解释
        A线程中b.interrpt()执行,B线程刚开始准备执行sleep或wait,执行时会检查线程的状态,如果为中断状态,则跑出InterrptedException异常。线程的【中断状态】会立马被清除掉。

Two-phapse-Termination 例子
主线程A(要停掉B线程)

 package com.yeepay.sxf.thread10;
/**
* 测试主线程A线程
* @author sxf
*
*/
public class Test {
public static void main(String[] args) {
//开启收拾玩具的线程
CountAddThread addThread=new CountAddThread();
//开启线程
new Thread(addThread).start();
//让主线程休息5秒
try {
Thread.sleep(5000);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
//关闭收拾玩具线程
addThread.shutDownRequest(); }
}

线程B(要被A线程停掉)

 package com.yeepay.sxf.thread10;

 public class CountAddThread extends Thread{
//计数器
private Integer counter=0; //当发送出停止线程的请求,该值设置为true
private volatile boolean flag=false; @Override
public void run() {
try {
while (!flag) {
doWork();
if(this.interrupted()){
System.out.println("CountAddThread.run(中断)");
}else{
System.out.println("CountAddThread.run(非中断)");
}
System.out.println("CountAddThread.run(sleep after收拾玩具个数:)"+counter);
}
} catch (Exception e) {
System.out.println("CountAddThread.run(取消sleep后,抛出异常抓住,收拾玩具个数:)"+counter);
e.printStackTrace();
}finally{
shutDownDoWork();
} } //具体工作内容
public void doWork() throws InterruptedException {
counter++;
System.out.println("CountAddThread.doWork(收拾玩具第)"+counter+"次数");
// Thread.sleep(10);
} //发送终止请求
public void shutDownRequest(){
System.out.println("CountAddThread.shutDownRequest(终止线程方法的请求启动)");
flag=true;
//将线程设置为中断状态
interrupt();
//判断this线程是否为中断状态
if(this.isInterrupted()){
System.out.println("CountAddThread.shutDownRequest(线程是中断)");
}else{
System.out.println("CountAddThread.shutDownRequest(线程为非中断状态)");
} } //判断终止请求是否已经发出
public boolean isShutDown(){
return flag;
} public void shutDownDoWork(){
System.out.println("CountAddThread.shutDownDoWork(结束请求后counter=>"+counter+")");
} }

一种异常抛出的实现

 package com.yeepay.sxf.thread10;
/**
* 抛异常一种实现
* @author sxf
*
*/
public class TestException { private Exception exception=null; public static void main(String[] args) {
TestException ex=new TestException();
try {
ex.addtest();
} catch (Exception e) {
// TODO Auto-generated catch block
System.out.println("TestException.main()"+e);
}
} public void addtest() throws Exception{
try {
int a=1/1;
} catch (Exception e) {
exception=e;
}
System.out.println("异常被抓住,但没抛,也没打印,而是赋值给别的对象,后边再抛");
if(exception!=null){
throw exception;
}
System.out.println("抛异常后边不可以写代码,也不会执行");
} }

多线程程序设计学习(11)Two-phapse-Termination pattern的更多相关文章

  1. 多线程程序设计学习(3)immutable pattern模式

    Immutable pattern[坚不可摧模式] 一:immutable pattern的参与者--->immutable(不变的)参与者        1.1:immutable参与者是一个 ...

  2. 多线程程序设计学习(10)Future pattern

    Future pattern[订单取货模式] 一:Future pattern的参与者--->Client(客户需求)--->Host(蛋糕门店)--->Data(票据和蛋糕的接口) ...

  3. 多线程程序设计学习(9)worker pattern模式

    Worker pattern[工作模式]一:Worker pattern的参与者--->Client(委托人线程)--->Channel(通道,里边有,存放请求的队列)--->Req ...

  4. 多线程程序设计学习(2)之single threaded execution pattern

    Single Threaded Execution Pattern[独木桥模式] 一:single threaded execution pattern的参与者--->SharedResourc ...

  5. 多线程程序设计学习(7)read-write lock pattern

    Read-Write Lock Pattern[读写]一:Read-Write Lock Pattern的参与者--->读写锁--->数据(共享资源)--->读线程--->写线 ...

  6. 多线程程序设计学习(13)Active Object pattern

    Active Object[接收异步消息的对象] 一:Active Object的参与者--->客户端线程(发起某种操作请求处理)--->代理角色(工头)--->实际执行者(工人)- ...

  7. 多线程程序设计学习(12)Thread-soecific storage pattern

    Thread-Specific-Storage[线程保管箱] 一:Thread-Specific Storage的参与者--->记录日志的线程(ClientThread)--->负责获取不 ...

  8. 多线程程序设计学习(6)Producer-Consumer模式

    Producer-Consumer[生产消费者模式]一:Producer-Consumer pattern的参与者--->产品(蛋糕)--->通道(传递蛋糕的桌子)--->生产者线程 ...

  9. 多线程程序设计学习(5)balking模式和timed模式

    Balking[返回模式]timed[超时模式]一:balking pattern的参与者--->GuardedObject(被警戒的对象) --->该模式的角色:模拟修改警戒对象的线程, ...

随机推荐

  1. 2016年辛星less教程发布了

    首先简介一下less吧,它是一个css预处理器.当我们的项目比较大的时候,我们的css的代码量也会急剧的膨胀,因此就有很多方案来让编程更加容易,没错,less就是这样一种技术. 在百度网盘的下载地址为 ...

  2. MVC5 Bundles发布到IIS失效问题解决方案

    MVC中Bundles可以提高代码的可重用性 我每个页面都需要用到这十几个JS+CSS 当我把MVC发布到服务器以后,Bundles中的JS和CSS会失效的时候 宝宝的心里是崩溃的.... 查了很多资 ...

  3. HTML 菜单 a 标签跳转本页面并追加参数

    代码如下: <!-- BEGIN 追加URL的参数 --> <script type="text/javascript"> function setUrl( ...

  4. iOS6 以上设置文本高度,行高(转)

    2013-12-09     我来说两句   来源:冻僵的企鹅'zone   收藏    我要投稿 在iOS 7之前,常用下面这个方法计算文本高度sizeWithFont:constrainedToS ...

  5. Java中的break与continue区别

    break跳出当前循环执行循环下面的程序, 如果break出现在嵌套循环的内层循环, 则break语句只会跳出当前层的循环; 当程序执行到continue时时, 则跳过本次循环程序重新回到循环开始继续 ...

  6. MoonWarriors-lua——《雷电战机》游戏-Lua移植版

    MoonWarriors是一个使用Cocos2d-Html5引擎开发的类似雷电战机的游戏Demo,源代码发布在Cocos2d-x官网的引擎示例当中.MoonWarriors-lua是为了学习Cocos ...

  7. shell复习笔记----查找与替换

    查找文档 以grep 程序查找文本(匹配文本 matching text)相当方便.传统上有三种程序可以用来查找整个文本文件. grep 最早的文本匹配程序.其最简单的方式就是使用固定字符串 $ wh ...

  8. What we learned in Seoul with AlphaGo

    What we learned in Seoul with AlphaGo March 16, 2016 Go isn’t just a game—it’s a living, breathing c ...

  9. KafkaSpout: PartitionManager的行为分析

    KafkaSpout的核心逻辑都是由PartitionManager来实现的. 但是这个类实现时候需要考虑的东西有些多,0.92至0.93,至当前(2015.3.14)的master一直在变化.在这里 ...

  10. Jetty实践-Hello World

    该程序摘自官网教程: 1.首先去Jetty官网,下载jetty-distribution-9.2.6.v20141205.zip,Jetty Jar包,解压到任意目录: 2.使用Eclipse新建一个 ...