多线程学习(五):Callable与FutureTask的简单实现
1. LazykingCallable public interface LazykingCallable<V> {
V call();
}
2. LazykingFutureTask public class LazykingFutureTask<V> implements Ru
多线程学习(四):Lock锁与线程优先级
1. Lock锁的基本用法 创建Lock实例 Lock lock = new ReentrantLock(); 使用lock()方法获取锁 使用unLock()方法释放锁 通常,一般unLock()方法会被放在finally块中,以保证在异常情况下lock锁被正常释放, private final
多线程学习(三):线程通知&等待机制
1. wait()/notify()的基本使用 wait()/notify()只能在synchronized同步代码块中使用 synchronized(锁对象) {
锁对象.wait();
}
synchronized(锁对象) {
锁对象.notify();
}
调用wait()方法的线程
多线程学习(二):线程安全问题
当线程执行到同步代码块时,会尝试获取锁对象的锁,以确保代码块在同一时间只能被一个线程执行。 1. 问题引入 同时开启两个线程,对同一个资源进行操作,线程之间互相干扰 什么是线程安全问题? 多线程同时修改同一资源,线程之间互相干扰,就会产生线程安全问题 public class ThreadSafe1
多线程学习(一):线程创建的方式
使用多线程时,不同方式最终都通过调用 Thread 类的 start 方法启动线程 1. 继承Thread类 继承Thread类 重写run()方法 需要执行的代码写在方法体中 调用start()方法 public class ThreadCreate1 extends Thread{