java线程如何停止
点启动按钮时该线程启动,且不会停止
然后点停止按钮时线程就可以停止,应该怎么做呢?
private class RunnableTest implements Runnable{
public void run()
{
int i=0;
while(start){
jt.setText(""+i);
try{
Thread.sleep(1000);
}catch(Exception e)
{
e.printStackTrace();
}
i++;
}
}
}
private class TextAreaHandler implements ActionListener{
public void actionPerformed(ActionEvent event){
if(event.getSource()==button1)//启动
{start=true;
rt.run();
}else{
start=false;//停止
jt.setText("停止");
}
}
因为长度限制,所以只留了主要部分 展开
2015-08-04 · 知道合伙人互联网行家
终止线程的三种方法:
1. 使用退出标志,使线程正常退出,也就是当run方法完成后线程终止。
2. 使用stop方法强行终止线程(这个方法不推荐使用,因为stop和suspend、resume一样,也可能发生不可预料的结果)。
3. 使用interrupt方法中断线程。
1. 使用退出标志终止线程
当run方法执行完后,线程就会退出。但有时run方法是永远不会结束的。如在服务端程序中使用线程进行监听客户端请求,或是其他的需要循环处理的任务。在这种情况下,一般是将这些任务放在一个循环中,如while循环。如果想让循环永远运行下去,可以使用while(true){……}来处理。但要想使while循环在某一特定条件下退出,最直接的方法就是设一个boolean类型的标志,并通过设置这个标志为true或false来控制while循环是否退出。下面给出了一个利用退出标志终止线程的例子。
package chapter2;
public class ThreadFlag extends Thread
{
public volatile boolean exit = false;
public void run()
{
while (!exit);
}
public static void main(String[] args) throws Exception
{
ThreadFlag thread = new ThreadFlag();
thread.start();
sleep(5000); // 主线程延迟5秒
thread.exit = true; // 终止线程thread
thread.join();
System.out.println("线程退出!");
}
}
在上面代码中定义了一个退出标志exit,当exit为true时,while循环退出,exit的默认值为false.在定义exit时,使用了一个Java关键字volatile,这个关键字的目的是使exit同步,也就是说在同一时刻只能由一个线程来修改exit的值,
2. 使用stop方法终止线程
使用stop方法可以强行终止正在运行或挂起的线程。我们可以使用如下的代码来终止线程:
thread.stop();
虽然使用上面的代码可以终止线程,但使用stop方法是很危险的,就象突然关闭计算机电源,而不是按正常程序关机一样,可能会产生不可预料的结果,因此,并不推荐使用stop方法来终止线程。
3. 使用interrupt方法终止线程
使用interrupt方法来终端线程可分为两种情况:
(1)线程处于阻塞状态,如使用了sleep方法。
(2)使用while(!isInterrupted()){……}来判断线程是否被中断。
在第一种情况下使用interrupt方法,sleep方法将抛出一个InterruptedException例外,而在第二种情况下线程将直接退出。下面的代码演示了在第一种情况下使用interrupt方法。
package chapter2;
public class ThreadInterrupt extends Thread
{
public void run()
{
try
{
sleep(50000); // 延迟50秒
}
catch (InterruptedException e)
{
System.out.println(e.getMessage());
}
}
public static void main(String[] args) throws Exception
{
Thread thread = new ThreadInterrupt();
thread.start();
System.out.println("在50秒之内按任意键中断线程!");
System.in.read();
thread.interrupt();
thread.join();
System.out.println("线程已经退出!");
}
}
上面代码的运行结果如下:
在50秒之内按任意键中断线程!
sleep interrupted
线程已经退出!
在调用interrupt方法后, sleep方法抛出异常,然后输出错误信息:sleep interrupted.
注意:在Thread类中有两个方法可以判断线程是否通过interrupt方法被终止。一个是静态的方法interrupted(),一个是非静态的方法isInterrupted(),这两个方法的区别是interrupted用来判断当前线是否被中断,而isInterrupted可以用来判断其他线程是否被中断。因此,while (!isInterrupted())也可以换成while (!Thread.interrupted())。
现在一般都是这样实现的
我是用这种方法,可是点了启动按钮后线程好像就死锁了,界面就再也点不动了
private static boolean start=false;
..
如果按了启动按钮
start=true;
while(start){
//一系列的操作
Thread.sleep(1000);
}
如果按了停止按钮
start=false;
但是这样做只能进行一次这样的循环,如果你想在停止后还想能够继续开始,那么有2种方法,
1.在线程中加入2个循环,
while(bLoop)
{
while(start)
{
// ..............
}
}
2.在停止按钮的逻辑里面,先将start设为false,再把线程对象置为null,然后重新创建一个线程
纯手打,谢谢采纳、
那个是打字的时候落下了,启动按钮的响应里第一步就是start=true;
可是你这样做的话bloop应该由什么事件控制呢,我不明白为什么sleep的时候程序界面就完全不能动了,如果sleep的时候能响应其它事件,点了停止按钮那start变为了false,线程就会停止的啊
检查你的开始按钮里面的逻辑,子线程的sleep 不会影响到主线程的啊,如果主线程死掉,肯定是代码有问题,捕获异常,打印看看。
有继承线程类,或实现Runnable吗?
如果没有这样,那你做的想当于在同一个线程里做了一个死循环。
下边是个例子,你参考一下,
点开始过度条在动,点一下暂停,会停下来,再点一下暂停又会动起来。
点stop会停下来,你看一下。
----------------------------------------------------------------
import java.awt.Dimension;
import java.awt.Toolkit;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JProgressBar;
import javax.swing.JToolBar;
import javax.swing.JButton;
import java.awt.event.ActionListener;
import java.awt.event.ActionEvent;
public class Table extends JFrame implements Runnable {
private JProgressBar progress = new JProgressBar();
private boolean start = false;
private boolean pause = false;
private JButton btnStart;
public Table() {
setResizable(false);
getContentPane().setLayout(null);
JToolBar toolBar = new JToolBar();
toolBar.add(new JLabel("state"));
toolBar.add(progress);
toolBar.setFloatable(false);
toolBar.setBounds(0, 247, 454, 21);
getContentPane().add(toolBar);
btnStart = new JButton("start");
btnStart.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent e) {
login();
}
});
btnStart.setBounds(12, 10, 91, 21);
getContentPane().add(btnStart);
JButton btnPause = new JButton("Pause");
btnPause.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent e) {
pause = !pause;
}
});
btnPause.setBounds(131, 10, 91, 21);
getContentPane().add(btnPause);
JButton btnStop = new JButton("stop");
btnStop.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent e) {
start = false;
}
});
btnStop.setBounds(241, 10, 91, 21);
getContentPane().add(btnStop);
setDefaultCloseOperation(EXIT_ON_CLOSE);
setLocationRelativeTo(null);
setSize(460, 300);
Dimension screenSize = Toolkit.getDefaultToolkit().getScreenSize();
setLocation((screenSize.width - getWidth()) / 2,
(screenSize.height - getHeight()) / 2);
setVisible(true);
}
public static void main(String[] args) {
new Table();
}
private void login() {
start = true;
btnStart.setEnabled(false);
new Thread(this).start();
}
public void run() {
int value = 0;
while (start) {
try {
if (pause) {
Thread.sleep(50);
continue;
}
progress.setValue(value++);
if (progress.getValue() == progress.getMaximum()) {
break;
}
Thread.sleep(50);
} catch (Exception e) {
}
}
}
}