可以通过线程的方法进行基本的线程控制,除了已知的start、run、sleep方法外还有isAlive、currentThread、interrupt方法。
isAlive:该方法用来测试线程是否处于活动状态。线程由start方法启动后,直至被终止之间的任何时刻都处于Alive状态。当处于新建状态和死亡状态时,该方法返回false。
currentThread:该方法是Thread类的的类方法,返回正在使用CPU资源的线程。
interrupt:当线程处于休眠状态时,一个占有CPU资源的线程可以让休眠的线程调用interrupt方法唤醒自己,导致休眠的线程发生InterruptedException异常结束休眠,重新排队等待CPU资源。
class A implements Runnable{
Thread student,teacher;
A(){
teacher=new Thread(this,"王教授");
student=new Thread(this,"张三");
}
public void run(){
if(Thread.currentThread()==student){
try{
System.out.println(student.getName()+"正在睡觉,不听课");
Thread.sleep(1000*60*60);
}catch(InterruptedException e){
System.out.println(student.getName()+"被老师叫醒了");
}
}
else if(Thread.currentThread()==teacher){
for(int i=1;i<=3;i++){
System.out.println("上课!");
}try{
Thread.sleep(500);
}catch(InterruptedException e){}
student.interrupt();
}
}
}
public class BasicControlThread{
public static void main(String args[]){
A a=new A();
a.student.start();
a.teacher.start();
}
}
此外还有stop和join方法
stop():通过调用线程的实例方法stop()来终止线程,终止后即进入死亡状态,不能再被调度。
join():一个线程在占有CPU资源期间,可以让其他线程调用join()方法和本线程联合。当前线程等待调用该方法线程结束后,再重新排队等待CPU资源,以便恢复执行。
class TV{
float price;
String name;
TV(String name,float price){
this.price=price;
this.name=name;
}
}
class ThreadJoin implements Runnable{
TV tv;
Thread customer,tvMaker;
ThreadJoin(){
customer=new Thread(this,"顾客");
tvMaker=new Thread(this,"电视制造商");
}
public void run(){
if(Thread.currentThread()==customer){
System.out.println(customer.getName()+"等"+tvMaker.getName()+"生产电视机");
try{
tvMaker.join();//线程customer开始等待tvMaker结束
}catch(InterruptedException e){ }
System.out.println(customer.getName()+"买了一台电视机"+tv.name+"价格:"+tv.price);
}
else if(Thread.currentThread()==tvMaker){
System.out.println(tvMaker.getName()+"开始生产电视机...");
try{
tvMaker.sleep(2000);
}catch(InterruptedException e){ }
tv=new TV("长虹牌",4500);
System.out.println(tvMaker.getName()+"生产完毕!!!");
}
}
}
public class JoinThread{
public static void main(String args[]){
ThreadJoin th=new ThreadJoin();
th.customer.start();
th.tvMaker.start();
}
}