java线程编程(一):线程基础
在学习java中,我发现有关于对线程的讲解比较少,我打算为一些java初学者提一些关于线程方面的参考,
为深入学习java奠定基础。我本着共同进步的原则特写下了关于java线程编程的一系列文章
java线程编程(一):线程基础
◆线程(thread)其实是控制线程(thread of control)的缩写.
每一个线程都是独立的,因此线程中的每个方法的局部变量都是和其他线程隔离开的,这些变量完全是私有的,因此对于
线程而言,是没有办法访问其他线程的局部变量的。如果两个线程同时访问同一个方法,则每个线程得到一个单独的此方法的
局部变量的拷贝。
◆通过Thread类创建线程
public classs test{
public void run(){
for (int i;i<100;i++){
System.out.println("hello_"+i);
}
}
}
将会输出hello_0,一直到hello_99;
如果我们在Applet中调用这个方法,他就会在Applet的线程中运行。
impot java.applet.Applet;
public class test extends Applet{
public void init(){
test tt=new test();
tt.run();
}
}
如果我们想让test的run()方法与applet的init()一起运行,该怎么做呢?
应该使test成为thread(java.lang.Thread)的子类.
程序修改为:
public classs test extends Thread{
public void run(){
for (int i;i<100;i++){
System.out.println("hello_"+i);
}
}
}
接下来我们还要修改Applet:
impot java.applet.Applet;
public class test extends Applet{
public void init(){
test tt=new test();
tt.start();
}
}
对ran()方法的调用变成了对start()方法的调用。
对此我们做一些说明:
Thread
创建一个进程化的对象
void run()
新创建的线程会执行这个方法
void start()
创建一个新的线程并运行这个线程类中定义的run()方法。
下面我们来看一个例子
import java.awt.*;
public class TimerThread extends Thread{
Componet comp;//需要重画的组件
int timediff;//组件重画的间隔时间
volatile boolean shouldrun;//设为false为停止线程
public TimerThread (Compond comp,int timediff){
this.comp = comp;
this.timediff = timedifff;
shouldrun = true;
}
public void run(){
while(shouldrun){
try{
comp.repaint();
sleep(timediff);
}catch(Exception e){}
}
}
}
sleep()方法是Thread类的一部分,他使得当前线程停止一定的时间。
static void sleep(long millseconds)
睡眠时间指定为毫秒
static void sleep(long millseconds ,int nanoseconds)
睡眠时间指定为毫秒和纳秒这个方法是静态的。
线程的停止,一般不推荐使用
stop()方法,使用stop()方法是危险的,将会导致异常。
◆使用Runable接口的线程
java语言使用一种称为接口的机制,来解决其不支持的多重继承。
Runnable接口只使用一个方法run()方法.
public classs test implements Runnable{
public void run(){
for (int i;i<100;i++){
System.out.println("hello_"+i);
}
}
}
同时相应的程序修改为:
impot java.applet.Applet;
public class test extends Applet{
public void init(){
Runnable tt=new test();
Thread th= new Thread(tt);
th.start()´
}
}
◆线程周期
boolean isAlive()
用来判断一个线程是不是活动的
线程启动并不意味着线程正在运行或可以运行了,这是这个原因
isAlive()才经常被用来检测线程是否正在运行。
简单的一段小程序
...
while(timer.isAlive())
{
try{
Thread.sleep(100);
}catch(InterruptedException e){}
}
void jion()
等待指定的线程运行结束
当线程不活动时,jion()才会返回
void jion(long timeout)
等待指定的线程运行结束,但不超过指定的超时值
下节主要交流一下
线程的同步技术
|