java多线程编程01 - 基本API&停止线程

- isAlive()

判断当前线程是不是处于活动状态(运行态或者就绪态)

- getXX

getName(), getId() 取得进程名字和唯一标识。

- currentThread()

可以返回当前代码段是在被哪个线程执行的信息。
注意和 this 进行区别: this执行的是当前的新线程的对象, currentThread()指向的是当前执行的线程对象。 在新线程的构造方法里,调用this.isAlive() = false; 代表当前子线程还没有start;但是currentThread.isAlive() = true,因为这指向的是调用子线程的主线程。

Thread.currentThread()this.currentThread()在大部分情况下结果是相同的,都是调用Thread的静态方法currentThread(),若当前子类重写了父类的currentThread()方法,那么Thread.currentThread()和this.currentThread()返回的结果会不同。

- sleep()

让当前正在执行的线程休眠指定的毫秒数,哪个线程里面调用了,就休眠哪个。

- 停止线程

停止正在运行的线程有3种方法,这里先用interrupt()方法举例,在后面会介绍其他的。
interrupt() 并不能马上停止线程,只是在当前线程中打开了一个停止标志,并不是真的停止。
先来判断一下进程是否是停止状态:interrupted()测试的是当前线程是否已经中断 (静态的方法)

public class Test {
	public static void main(String[] args) {
		try {
			MyThread myThread = new MyThread();
			myThread.start();
			Thread.sleep(1000);   // 不是用myThread调用的,让主进程休眠
			myThread.interrupt(); // 对子线程中断
			//myThread.interrupted()和Thread.interrupted()是一样的,interrupted()是静态方法
			System.out.println("是否停止1:" + myThread.interrupted());
			System.out.println("是否停止2:" + myThread.interrupted());	
		} catch (Exception e) {
			// TODO: handle exception
		}
		System.out.println("end!");
	}
}

class MyThread extends Thread {
	 private int count = 5;
		
	 @Override
	 public void run() {
		 super.run();
         for (int i = 0; i < 100; ++i) {
        	 System.out.println("i= " + (i + 1));
         }
	 }
}
输出:
(省略前边打印)
是否停止1false
是否停止2false
end!

从控制台的打印来看,线程并没有停止,这说明:interrupted()测试的是当前线程是否已经中断 不管这个方法是这个当前线程是 main ,它从来没有被中断过,所以打印的两个结果是false;如果想让main产出中断,要在main方法体内写Thread.currentThread().interrupt(); 输出:

是否停止1:true
是否停止2:false

第一个true :这个interrupted()确实判断出来当前进程停了,但是第二个是false,因为线程的中断状态由该方法清除,也就是说,如果两次调用这个方法,第二次调用返回false(在第一次调用已经清除中断状态之后,第二次检验中断状态就是非中断)

**isInterrupted() 测试的是线程是否已经中断 (方法不是静态的) **

myThread.interrupt(); 
System.out.println("是否停止1:" + myThread.isInterrupted());
System.out.println("是否停止2:" + myThread.isIinterrupted());	

这样两个输出都是true,这就是说明isInterrupted()必须被相应好的进程对象调用(非静态决定的)而且不清除中断标志。也就是说:谁调用,就判断谁是不是中断。 而上面的interrupted() 是静态的,不管你是用类名Thread直接调还是用对象调,它都站在全局的高度,判断当前执行的进程 (就是这个interrupted() 语句代码所在的那个线程)是不是中断了。

抛出异常停止线程
@Override
	 public void run() {
		 super.run();
		 try {
			    for (int i = 0; i < 10000; ++i) {
					if (this.interrupted()) {
						System.out.println("中断了,我要停止了!");
						throw new InterruptedException(); // 抛出异常
					}
					System.out.println("i= " + (i + 1));
	             }
		 } catch (InterruptedException e) {
			// TODO: handle exception
			 System.out.print("进入catch,说明异常中断了!");
		}
	 }
在睡眠中中断
public class Test {
	public static void main(String[] args) {
		try {
			MyThread myThread = new MyThread();
			myThread.start();
			Thread.sleep(200); 
			myThread.interrupt();
		} catch (InterruptedException  e) {
			// TODO: handle exception
			System.out.println("main catch!");
		}
		System.out.println("end!");
	}
}
class MyThread extends Thread {
	 @Override
	 public void run() {
		 super.run();
		 try { 
			 System.out.println("run start!");
			 Thread.sleep(200000);
			 System.out.println("run end!");
		 } catch (InterruptedException e) {
			 System.out.print("我还在sleep呢,就被main给中断了!");
		}
	 }
}
输出:
run start!
end!
我还在sleep呢,就被main给中断了!

从打印结果看,如果在sleep状态下停止一个线程,会进入这个线程的catch语句,并且清除停止状态值,变成false。

stop 暴力停止(不推荐) myThread.stop();

方法stop() 已经作废了,因为强制停止的话有一些清理工作不能完成,而且对锁对象解锁,可能导致数据不同步。

return 停止线程

用return代替异常throws语句,直接返回。但是也不建议,因为用上面第一种抛出异常的方法,在catch语句里还可以将异常向上抛出,进行线程停止事件的广播等。

—2019.12. 17 -------------科研楼506
期末马上来了,好慌啊。。。
研究生为什么还要考试,还是闭卷。。。。。。
😔
打字好慢,什么时候才能拥有像康康或者旁边的doctor陈和doctor李一样的手速

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值