Java多线程之线程中止
shop()
Java中提供了shop()方法來中斷線程,但其過于暴力而被定義為過期方法。假如一條線程在修改一段數據時,且已經修改了一半,此時的你強行用shop()方法中斷該線程后,數據處于一半修改過、一半未修改的狀態,該數據就已經廢了(且不會有任何提示)。除非你清楚在干什么,否則不要使用shop()。
Java中推薦使用中斷:
public void Thread.interrupt() //中斷線程
public boolean Thread.isInterrupted()? ? //判斷是否被中斷
public static boolean Thread.interrupted()? ? //判斷是否被中斷,且清除當前中斷狀態
public static void main(String[] args) throws InterruptedException {Thread t1 = new Thread() {@Overridepublic void run () {while (true) {Thread.yield();}} };t1.start();Thread.sleep(2000);ti.interrupt(); } 復制代碼在這里雖然調用了interrupt()方法,但該線程并不會停下。因為該方法只是設置了一個中斷狀態,但該線程并未對此中斷狀態做出反應。
以下代碼進行了對中斷狀態的處理。
public static void main(String[] args) throws InterruptedException {Thread t1 = new Thread() {@Overridepublic void run () {while (true) {if (Thread.currentThread().isInterrupted()){? ? ?//此方法返回中斷狀態,且不會清除該中斷狀態。System.out.println("Interruted!");breadk;}Thread.yield();}} };t1.start();Thread.sleep(2000);ti.interrupt(); } 復制代碼但我們使用wait() 或者 sleep() 方法時要注意下:
首先得了解下Thread.sleep()函數:
public static native void sleep(long millis) throws InterruptedException
當該線程休眠時如果中斷則會拋出該錯誤,此異常非運行時異常,必須捕獲且處理。
public static void main(String[] args) throws InterruptedException {Thread t1 = new Thread() {@Overridepublic void run () {while (true) {if (Thread.currentThread().isInterrupted()){//此方法返回中斷狀態,且不會清除該中斷狀態System.out.println("Interruted!");break;}try {Thread.sleep(2000);} catch (InterruptedException e) {System.out.println("Interruted When Sleep");// 設置中斷狀態Thread.currentThread().interrupt();}Thread.yield();}} };t1.start();Thread.sleep(2000);t1.interrupt(); } 復制代碼在catch語塊中本可以進行中斷退出,但我們沒這么做,因為這樣會破壞數據一致性和完整性(和直接使用shop()用異曲同工之妙)。所以我們在異常處理中必須重新設置中斷狀態(因為此時拋出異常后狀態會被清除),讓該線程完成工作后再退出。
總結
以上是生活随笔為你收集整理的Java多线程之线程中止的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Go 类型别名与类型声明的区别
- 下一篇: 阿里1682亿背后的协同研发云——云效正