您好,登录后才能下订单哦!
这篇文章给大家分享的是有关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)
等待指定的线程运行结束,但不超过指定的超时值
感谢各位的阅读!关于“java线程编程的示例分析”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。