我认为他们所暗示的也是如果使用软引用映射,则应该为最大的内存使用做好准备,并且可能会有更多的gc活动,因为仅释放内存需要对gc进行引用。
如果您知道只需要高速缓存中的最后n个值,则使用LRU高速缓存是一种更精简的方法,可为正在运行的应用程序提供更多可预测的资源使用情况。
此外,根据这个,好像有-server和-client
JVM的之间行为的细微差别。
Sun
JRE确实将SoftReference与WeakReferences区别对待。如果可用内存没有压力,我们尝试保留由SoftReference引用的对象。一个细节:“-client”和“
-server” JRE的策略不同:-client JRE倾向于通过清除SoftReferences而不是扩展堆来减小占用的空间,而-server
JRE试图保持您的占用空间。通过扩大堆(如果可能)而不是清除SoftReferences,可以提高性能。一种尺寸并不适合所有尺寸。



