关于java多线程的一些知识点

多线程是一种并发编程的技术,允许在同一程序中同时执行多个线程。在Java中,多线程编程是非常常见的,因为它可以提高程序的性能和响应能力。以下是关于Java多线程的一些重要概念和示例代码:

线程的创建

  • 使用Thread类:通过继承Thread类并覆盖run方法来创建线程。
class MyThread extends Thread {
    public void run() {
        // 线程执行的代码
    }
}

MyThread thread = new MyThread();
thread.start(); // 启动线程
  • 使用Runnable接口:实现Runnable接口,然后将其传递给Thread对象。 

线程的生命周期:

  • 新建状态(New):线程被创建但还未启动。
  • 运行状态(Runnable):线程正在执行或准备执行。
  • 阻塞状态(Blocked):线程被挂起,等待某些条件的发生(如获取锁、IO操作等)。
  • 等待状态(Waiting):线程等待其他线程的通知或等待一段时间。
  • 超时等待状态(Timed Waiting):线程在规定的时间内处于等待状态。
  • 终止状态(Terminated):线程执行完成或因异常退出。

 线程同步:

  • synchronized关键字:Java提供了synchronized关键字来实现对共享资源的访问同步。通过对synchronized代码块或方法进行加锁,只有获得锁的线程才能执行该代码块或方法。
  • ReentrantLock类:除了synchronized关键字,Java还提供了ReentrantLock类来实现锁定。ReentrantLock类具有更高的灵活性,并提供了更多的功能,例如可重入、公平性等。

 线程池:

线程池是一组线程的集合,可以重用和管理这些线程。它提供了一个线程队列,用于存储任务并按需执行。Java提供了Executor框架和线程池接口(如ExecutorService)来方便地创建和管理线程池。

线程间的通信:

  • wait()和notify()方法:线程可以使用wait()方法暂停自己的执行,并通过notify()方法通知其他线程继续执行。这是基于等待/通知机制的典型示例。
  • Condition接口:Java的Lock类提供了Condition接口,它可以更灵活地控制线程的等待和唤醒操作。
  • 信号量(Semaphore):信号量是一种多线程同步的机制,用于控制对共享资源的访问。信号量可以用来限制同时访问某个资源的线程数量。下面是一个简单的Java多线程示例,演示如何创建并启动两个线程:

class MyThread extends Thread {
    public void run() {
        for (int i = 1; i <= 5; i++) {
            System.out.println("Thread 1: " + i);
        }
    }
}

class MyRunnable implements Runnable {
    public void run() {
        for (int i = 1; i <= 5; i++) {
            System.out.println("Thread 2: " + i);
        }
    }
}

public class Main {
    public static void main(String[] args) {
        MyThread thread1 = new MyThread();
        Thread thread2 = new Thread(new MyRunnable());

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

这个示例创建了两个线程,一个继承自Thread类,另一个实现了Runnable接口,它们并发执行,输出各自的计数。多线程编程需要谨慎处理线程同步和共享资源,以确保程序的正确性和可靠性。 

你可能感兴趣的:(java,java,开发语言)