《大型网站系统与Java中间件实践》
1、对于wait/notify和notifyAll的调用都必须是在对象的synchronized块中。
2、volatile只是保证同一变量在多线程中的可见性,所以它更多是用于修饰作为开关变量的状态。
3、AtomicInteger内部通过JNI的方式使用了硬件支持的CAS指令,性能很好。
其他
NIO中Buffer.flip()操作是: 当向buffer进行一定量的写入(put或者从Channel读入)之后, 需要切换(翻转)到可读模式(limit置为position, position置为0)的一个必要操作.
—- 对Buffer的写入之后, 即将从Buffer进行读, 需要对读取的起点进行归位.
ByteBuffer.compat()则是在对Buffer进行尽可能多的读取之后, 防止有”未被读干净”的数据, 可能会被接下来的写入操作冲掉, 而进行的一种保留未读数据的操作.
本文探讨了Java中wait/notify及notifyAll的正确使用方法,并强调了这些方法必须在synchronized块中调用。此外,还介绍了volatile关键字的作用及其适用场景,以及AtomicInteger的高效实现原理。最后,讲解了NIO中Buffer的flip和compact方法的具体用途。
3533

被折叠的 条评论
为什么被折叠?



