在语音社交源码的运行当中,会有很多线程会在系统中进行,对于不同的线程我们希望实现不同的效果,今天我们主要来了解一下如何让两个线程按照指定的方式有序相交。
如果现在我们希望 B线程在 A 线程打印 1 后立即打印 1,2,3,然后 A 线程继续打印 2,3,那么我们需要更细粒度的锁来控制执行顺序。
在这里,我们可以利用 object.wait() 和 object.notify() 方法,代码如下:
public static void demo3() {
Object lock = new Object();
Thread A = new Thread(() -> {
synchronized (lock) {
System.out.println("A 1");
try {
lock.wait();
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println("A 2");
System.out.println("A 3");
}
});
Thread B = new Thread(() -> {
synchronized (lock) {
System.out.println("B 1");
System.out.println("B 2");
System.out.println("B 3");
lock.notify();
}
});
A.start();
B.start();
}
得到的结果如下:
A 1
B 1
B 2
B 3
A 2
A 3
上述代码的执行流程如下:
首先我们在语音社交源码中创建一个由 A 和 B 共享的对象锁: lock = new Object();
当A拿到锁时,先打印1,然后调用lock.wait()方法进入等待状态,然后交出锁的控制权;
B 不会被执行,直到 A 调用该lock.wait()方法释放控制权并且 B 获得锁;
B拿到锁后打印1,2,3,然后调用lock.notify()方法唤醒正在等待的A;
A 唤醒后继续打印剩余的 2,3。
为了便于理解,我将上面的代码添加了日志,代码如下:
public static void demo3() {
Object lock = new Object();
Thread A = new Thread(() -> {
System.out.println("INFO:A 等待获取锁");
synchronized (lock) {
System.out.println("INFO:A 获取到锁");
System.out.println("A 1");
try {
System.out.println("INFO:A 进入 waiting 状态,放弃锁的控制权");
lock.wait();
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println("INFO:A 被 B 唤醒继续执行");
System.out.println("A 2");
System.out.println("A 3");
}
});
Thread B = new Thread(() -> {
System.out.println("INFO:B 等待获取锁");
synchronized (lock) {
System.out.println("INFO:B 获取到锁");
System.out.println("B 1");
System.out.println("B 2");
System.out.println("B 3");
System.out.println("INFO:B 执行结束,调用 notify 方法唤醒 A");
lock.notify();
}
});
A.start();
B.start();
}
得到的结果如下:
INFO:A 等待获取锁
INFO:A 获取到锁
A 1
INFO:A 进入 waiting 状态,放弃锁的控制权
INFO:B 等待获取锁
INFO:B 获取到锁
B 1
B 2
B 3
INFO:B 执行结束,调用 notify 方法唤醒 A
INFO:A 被 B 唤醒继续执行
A 2
A 3
以上便是“语音社交源码开发,两个线程按照指定方式有序相交的实现”的主要代码,希望对大家有帮助。