Java实现多线程的三种方式:继承Thread类、实现Runnable接口、用Executable、Callable和Future实现。其中只有第三种可以在线程间传递数据。
只有操作是原子性的,才不会引发线程安全问题。即操作一次性完成,不会被其他线程中断。i++操作不是原子性,涉及到读-改-写操作。
可以用java.util.concurrent.atomic中的原子变量和原子操作,如AtomicLong
synchronized关键字:是Java提供的强制原子性内部锁机制,包括两部分内容:
synchronized(lock){
//...
}
synchronized锁属于互斥锁,A占用锁的时候,B必须等待或阻塞。内部锁是可重进入(reentrancy)的,子类可以重写父类的方法。
在synchronized锁代码块内的代码是串行(serialized)执行的,耗时操作如I/O读取不能放在synchronized代码块内,不能占用锁。