欢迎访问宙启技术站
智能推送

如何在Java中使用Thread函数来实现并发编程?

发布时间:2023-06-09 06:21:13

Java语言中提供了Thread类来支持并发编程,能够将多个任务同时运行,可以让应用程序在多个线程之间实现并行处理,以提高程序的运行效率和响应速度。本文将介绍Java中如何使用Thread函数来实现并发编程。

1. 创建线程

Java中创建新线程有两种方式,一种是继承Thread类,另一种是实现Runnable接口。

(1)继承Thread类的方式:

public class MyThread extends Thread {

    @Override

    public void run() {

        //线程执行的代码

        System.out.println("MyThread is running...");

    }

}

(2)实现Runnable接口的方式:

public class MyRunnable implements Runnable {

    @Override

    public void run() {

        //线程执行的代码

        System.out.println("MyRunnable is running...");

    }

}

2. 启动线程

创建线程对象后,需要调用start()方法来启动线程,该方法将会在新线程中自动调用run()方法。

(1)通过继承Thread类创建的线程:

public static void main(String[] args) {

        MyThread myThread = new MyThread();

        myThread.start();

}

(2)通过实现Runnable接口创建的线程:

public static void main(String[] args) {

        MyRunnable myRunnable = new MyRunnable();

        Thread myThread = new Thread(myRunnable);

        myThread.start(); 

}

3. 线程状态

Java线程状态包括以下值:

(1)NEW:新线程,还未执行。

(2)RUNNABLE:线程正在运行,或者在等待CPU资源。

(3)BLOCKED:线程阻塞于锁定的监视器上等待某个监视器的通知,无法继续执行。

(4)WAITING:线程正在等待某个条件的发生,例如等待用户输入,或者在执行Object.wait()方法时等待监视器被唤醒。

(5)TIMED_WAITING:等待某个条件的发生一段时间后,将被自动唤醒。

(6)TERMINATED:线程已经执行完毕,线程将被终止。

4. 线程同步和互斥

当多个线程同时访问某个共享资源时,会发生并发访问的问题,需要通过线程同步和互斥机制来解决。

(1)线程同步

当多个线程同时访问一个对象时,为了避免出现并发访问的问题,需要加入同步代码块或者同步函数,以保证线程之间的同步执行。

public synchronized void add(int number) {

        this.count += number;

}

上面的add方法是同步方法,可以保证在该方法执行时,只有一个线程能够访问该对象中的共享数据count,其他线程需要等待当前线程执行完该方法后才能访问。

(2)线程互斥

当多个线程同时访问不同的资源时,需要使用锁机制来保证线程之间的互斥执行,以避免竞争问题。

synchronized (obj) {

        //同步操作

}

上面的代码使用了synchronized来定义了一个锁对象obj,在代码块执行期间,只有一个线程能够拥有它,其他线程需要等待当前线程执行完该代码块后才能获取锁对象并执行。

5. 多线程协作和通信

当多个线程需要协作执行,需要使用等待/通知机制来实现线程之间的通讯。

(1)等待/通知机制

Java中提供了Object类中的wait和notify方法,可以使用它们来实现线程之间的等待和通知。

public class ThreadA extends Thread {

    private final Object lock;

    public ThreadA(Object lock) {

        this.lock = lock;

    }

    @Override

    public void run() {

        synchronized (lock) {

            System.out.println("ThreadA is start");

            try {

                lock.wait();

            } catch (InterruptedException e) {

                e.printStackTrace();

            }

            System.out.println("ThreadA is notified");

        }

    }

}

public class ThreadB extends Thread {

    private final Object lock;

    public ThreadB(Object lock) {

        this.lock = lock;

    }

    @Override

    public void run() {

        synchronized (lock) {

            System.out.println("ThreadB is start");

            lock.notify();

            System.out.println("ThreadB is done");

        }

    }

}

上面的代码演示了如何通过Wait和Notify方法实现线程之间的等待/通知机制。

(2)管道通信

Java提供了PipedInputStream和PipedOutputStream来实现线程之间的管道通信。

public class Sender extends Thread {

    private final PipedOutputStream out;

    public Sender() throws IOException {

        out = new PipedOutputStream();

    }

    public PipedOutputStream getOut() {

        return out;

    }

    @Override

    public void run() {

        try {

            out.write("Hello, receiver".getBytes());

            out.flush();

            out.close();

        } catch (IOException e) {

            e.printStackTrace();

        }

    }

}

public class Receiver extends Thread {

    private final PipedInputStream in;

    public Receiver(PipedOutputStream out) throws IOException {

        in = new PipedInputStream(out);

    }

    @Override

    public void run() {

        try {

            byte[] bytes = new byte[1024];

            int length = in.read(bytes);

            System.out.println(new String(bytes, 0, length));

            in.close();

        } catch (IOException e) {

            e.printStackTrace();

        }

    }

}

上面的代码演示了如何通过PipedInputStream和PipedOutputStream来实现线程之间的管道通信。

总结:

Java的线程机制提供了很多方法和类来支持并发编程,可以很方便地实现线程的创建、销毁、同步和互斥、协作和通信等操作,能够提高程序的运行效率和响应速度。但是也需要注意线程之间的竞争和死锁问题,以避免出现大量的Bug和性能问题。