在 Java 中,AQS(AbstractQueuedSynchronizer)是一个并发工具类,用于实现锁或者其他同步器的基础框架。
AQS 并不直接处理中断,而是通过实现 ReentrantLock 等类的 tryAcquireInterruptibly 方法来支持中断。当线程通过调用 tryAcquireInterruptibly 方法尝试获取锁时,如果线程被中断,那么它将抛出 InterruptedException 异常,此时需要根据业务需求进行处理。
下面是使用 ReentrantLock 以及 tryAcquireInterruptibly 方法支持中断的示例代码:
class MyTask implements Runnable {
private final ReentrantLock lock = new ReentrantLock();
@Override
public void run() {
try {
lock.lockInterruptibly();
// 获取锁后执行任务
System.out.println(Thread.currentThread().getName() + "获取了锁");
} catch (InterruptedException e) {
// 线程在等待锁的过程中被中断,处理中断逻辑
e.printStackTrace();
} finally {
lock.unlock();
}
}
}
public class InterruptTest {
public static void main(String[] args) {
MyTask task = new MyTask();
Thread thread1 = new Thread(task);
Thread thread2 = new Thread(task);
thread1.start();
thread2.start();
// 中断线程2的等待锁,线程2会抛出 InterruptedException 异常
thread2.interrupt();
}
}
在上述示例代码中,线程1和线程2都会竞争一个锁,如果线程2在等待锁时被中断,那么它将抛出 InterruptedException 异常。在实际业务中,可以根据需要在 catch 块中处理中断逻辑,例如释放资源,重新抛出异常等。