JAVA线程实现及控制

线程周期

JAVA的线程实现有2种方式:

方式一:继承Thread类

  1. 定义一个MyThread类继承Thread类
  2. 在MyThread类中重写run()方法
  3. 创建MyThread类的对象
  4. 启动线程

基于方式一列出以下三种控制方式

1、Thread.sleep

使当前正在执行的线程暂停制定的毫秒数

线程类:

package Thread;

public class Mythread extends Thread{

    public Mythread() {
    }
    public Mythread(String name) {
        //supper将参数指向父类的参数构造方法
        super(name);
    }

    @Override
    public void run() {
        for(int i=0;i<100;i++){
            System.out.println(getName()+">>>>>>"+i);
            try {
                Thread.sleep(100);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
    }
}

测试类:

package Thread;

public class Mythreaddemo1 {
    public static void main(String[] args) {
        Mythread mythread1 = new Mythread();
        Mythread mythread2 = new Mythread();
        mythread1.setName("高铁");
        mythread2.setName("飞机");

        //设置线程优先级
        mythread1.setPriority(10);
        //获取线程的优先级
        System.out.println(mythread1.getPriority());
        System.out.println(mythread2.getPriority());

        mythread1.start();
        mythread2.start();

    }
}

2、join()

等待这个线程死亡,才可以继续下一个线程

线程类:

package Thread;

public class Mythread extends Thread{

    public Mythread() {
    }
    public Mythread(String name) {
        //supper将参数指向父类的参数构造方法
        super(name);
    }

    @Override
    public void run() {
        for(int i=0;i<100;i++){
            System.out.println(getName()+">>>>>>"+i);
        }
    }
}

测试类:

package Thread;

public class Mythreaddemo1 {
    public static void main(String[] args) {

        Mythread mythread1 = new Mythread("高铁");
        Mythread mythread2 = new Mythread("飞机");
        Mythread mythread3 = new Mythread("汽车");

        mythread1.setPriority(10);
        //获取线程的优先级
        System.out.println(mythread1.getPriority());
        System.out.println(mythread2.getPriority());
        System.out.println(mythread3.getPriority());

        mythread1.start();
        //等待线程mythread1(高铁)执行完成,另外2个线程才可以继续执行
        try {
            mythread1.join();
        } catch (InterruptedException e) {
            e.printStackTrace();
        }

        mythread2.start();
        mythread3.start();
    }
}

3、setDaemon()

设置一个主线程,将其他线程设置为守护线程,当主线程执行完成之后,守护线程随即也自动结束

线程类:

package Thread;

public class Mythread extends Thread{

    public Mythread() {
    }
    public Mythread(String name) {
        //supper将参数指向父类的参数构造方法
        super(name);
    }

    @Override
    public void run() {
        for(int i=0;i<100;i++){
            System.out.println(getName()+">>>>>>"+i);
        }
    }
}

测试类:

package Thread;

public class Mythreaddemo1 {
    public static void main(String[] args) {

        Mythread mythread1 = new Mythread("高铁");
        Mythread mythread2 = new Mythread("飞机");
        Mythread mythread3 = new Mythread("汽车");

        mythread1.setPriority(10);
        //获取线程的优先级
        System.out.println(mythread1.getPriority());
        System.out.println(mythread2.getPriority());
        System.out.println(mythread3.getPriority());

        //设置主线程
        Thread.currentThread().setName("小毛驴车");
        //mythread1,mythread2,mythread3设置为守护线程,当主线程(小毛驴车)结束后,守护线程随即也结束
        mythread1.setDaemon(true);
        mythread2.setDaemon(true);
        mythread3.setDaemon(true);
        
        mythread1.start();
        mythread2.start();
        mythread3.start();
        for(int i=0;i<10;i++){
            System.out.println(Thread.currentThread().getName()+":"+i);
        }
    }
}

方式二:实现Runnable类

  1. 定义一个类MyRunnable实现Runnable接口
  2. 在MyRunnable类中重写run()方法
  3. 创建MyRunnable类的对象
  4. 创建Thread类的对象,把MyRunnable对象作为构造方法的参数
  5. 启动线程

实现Runnable接口并重写run方法:

package Thread;

public class MyRunnable implements Runnable{
    public MyRunnable() {
    }

    @Override
    public void run() {
        for (int i = 0; i < 100; i++) {
            System.out.println(Thread.currentThread().getName()+">>>>"+i);
        }
    }
}

测试类:

package Thread;

public class MyRunnableDemo1 {
    public static void main(String[] args) {
        MyRunnable runnable = new MyRunnable();

        Thread thread1 = new Thread(runnable,"飞机");
        Thread thread2 = new Thread(runnable,"高铁");

        thread1.start();
        thread2.start();

    }
}

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在 Java 中,可以使用以下方式实现线程阻塞: 1. 通过调用 `Thread.sleep()` 方法来使线程暂停一段时间。该方法会使当前线程暂停执行一段指定的时间,但不会释放线程所持有的锁。 ```java try { Thread.sleep(1000); // 线程暂停1秒钟 } catch (InterruptedException e) { e.printStackTrace(); } ``` 2. 使用 `wait()` 方法来使线程进入等待状态。当一个线程执行了 `wait()` 方法后,它会释放掉它所持有的锁,并且进入等待状态,直到被其它线程通过 `notify()` 或 `notifyAll()` 方法唤醒。 ```java synchronized (obj) { try { obj.wait(); // 线程进入等待状态 } catch (InterruptedException e) { e.printStackTrace(); } } ``` 3. 通过 `join()` 方法使一个线程等待另一个线程的执行完成。当一个线程执行了 `join()` 方法后,它会等待指定的线程执行完成后再继续执行。 ```java Thread thread = new Thread(new Runnable() { @Override public void run() { // 线程执行的代码 } }); thread.start(); try { thread.join(); // 等待指定线程执行完成 } catch (InterruptedException e) { e.printStackTrace(); } ``` 需要注意的是,当线程进入等待状态后,它会释放掉它所持有的锁,这是为了避免死锁的情况。因此,在使用 `wait()` 方法时,必须先获得锁对象的监视器锁。 ### 回答2: 在Java中,线程可以使用以下几种方法实现阻塞。 1. 使用`Thread.sleep()`方法:可以在线程中调用`Thread.sleep()`方法来阻塞线程的执行一段时间。该方法接受一个以毫秒为单位的参数,指定线程要休眠的时间。调用`Thread.sleep()`方法后,线程会进入阻塞状态,暂停执行指定的时间后恢复执行。 2. 使用`wait()`和`notify()`方法:线程可以使用`wait()`方法进入阻塞状态,在其他线程调用相同对象的`notify()`或`notifyAll()`方法时被唤醒。`wait()`和`notify()`方法通常与`synchronized`关键字一起使用,以确保线程安全。 3. 使用`Lock`和`Condition`:Java中的`Lock`接口提供了更灵活的线程同步机制,它可以替代`synchronized`关键字来实现线程的阻塞和唤醒。通过创建一个`ReentrantLock`对象,可以使用其`newCondition()`方法创建一个`Condition`对象。线程可以使用`Condition`的`await()`方法进入阻塞状态,并使用`signal()`或`signalAll()`方法通知其它线程。 4. 使用`BlockingQueue`:`BlockingQueue`是一个带有阻塞功能的队列,可以用来实现线程的阻塞和唤醒。线程可以调用`BlockingQueue`的`put()`方法将元素放入队列中,如果队列满了,线程会被阻塞等待;而调用`take()`方法从队列中取出元素,如果队列为空,线程也会被阻塞等待。 5. 使用`Future`和`Callable`:线程可以使用`Future`和`Callable`接口来实现阻塞。`Callable`是一个带有返回值的任务,而`Future`则是对任务执行结果的引用。通过调用`Future`的`get()`方法,线程可以阻塞等待任务的执行结果。 这些方法都可以在适当的地方使用,以实现Java线程的阻塞。具体使用哪种方法,取决于具体的应用场景和需求。 ### 回答3: 在Java中,线程可以通过以下几种方式实现阻塞。 1. Object类中的wait()和notify()方法:可以使用wait()方法使线程进入等待状态,直到其他线程调用相同对象上的notify()或notifyAll()方法才能被唤醒。 2. sleep()方法:通过Thread类的静态方法sleep(),可以使当前线程暂停执行一段时间。在睡眠期间,线程是阻塞的,不会占用CPU时间。 3. I/O阻塞:当线程执行输入/输出操作时,如果数据未就绪,线程会自动阻塞。例如,使用阻塞式的Socket读取或写入数据时,如果没有数据可用,线程将被阻塞,直到数据准备好。 4. 同步阻塞:当线程需要获取一个已经被其他线程持有的锁时,它将进入阻塞状态,直到锁被释放。这可以通过使用synchronized关键字来实现线程可以使用synchronized关键字来获取一个对象上的锁,并在执行同步代码块时阻塞其他线程的访问。 5. 等待线程执行完毕:可以使用Thread类的join()方法,使一个线程等待另一个线程执行完毕后再继续执行。调用join()方法的线程将被阻塞,直到目标线程执行完毕。 通过以上方式,可以在Java实现线程的阻塞。阻塞可以用于控制线程的执行顺序、提高程序的稳定性和效率。但要注意适当地使用阻塞,避免造成死锁或线程饥饿等问题。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值