在研究ReentrantLock类的实现时,我脑海中浮现出一个问题。 ReentrantLock是可序列化的,并且在文档中它表示任何反序列化的锁总是被解锁,而不管序列化时的状态如何。这是有道理的,因为状态锁定和解锁基本上是基于运行时的线程(谁持有锁),而我们反序列化这些线程可能不可用。
问题是:为什么我们需要Lock来保持,因为它不存储它的基本状态(锁定/解锁)?现在我可以假设可能是锁的公平性。但公平性又取决于底层操作系统,所以如果我们坚持锁定在一个平台上并在另一个平台上反序列化,因为(写一次并在任何地方运行)它可能不起作用所以没有必要坚持只是为了公平。
希望我清楚地对java中的锁序列化感到困惑。
答案 0 :(得分:6)
http://docs.oracle.com/javase/7/docs/api/java/util/concurrent/locks/Condition.html http://download.java.net/jdk7/archive/b123/docs/api/java/util/concurrent/locks/ReentrantLock.html
我想说Lock之所以存在,是因为你能够序列化依赖于Lock本身的对象。如果Lock不可序列化,那么依赖于它的任何东西也都无法序列化。
您还可以存储所有者,holdCount,queuedThreads以及您在上面为ReentrantLock链接的API页面上看到的所有其他内容。