<html>
  <head>

    <meta http-equiv="content-type" content="text/html; charset=ISO-8859-1">
  </head>
  <body bgcolor="#FFFFFF" text="#000000">
    Hello,<br>
    <br>
    We've recently been experimenting with the G1 collector for our
    application, and we noticed something odd with reference processing
    times in the G1. It is not clear to us if this is expected or
    indicative of a bug, but I thought I would mention it to this list
    to see if there is a reasonable explanation for this result.<br>
    <br>
    We are seeing that during the remark phase when non-strong
    references are processed, it takes around 20 times longer than the
    throughput collector spends processing the same number of
    references.  As an example, here is some output for references
    processing times we observed:<br>
    <br>
    <blockquote>2014-05-23T19:58:12.805+0000: 11446.605: [GC remark
      11446.618: [GC ref-proc11446.618: [SoftReference, 0 refs,
      0.0040400 secs]11446.622: [WeakReference, 11131810 refs, 8.7176900
      secs]11455.340: [FinalReference, 2273593 refs, 2.0022000
      secs]11457.342: [PhantomReference, 297950 refs, 0.3004680
      secs]11457.643: [JNI Weak Reference, 0.0000040 secs], 13.7534950
      secs], 13.8035420 secs]<br>
    </blockquote>
    <br>
    We see the G1 spent 8.7 seconds were spent processing 11 million
    weak references<br>
    <br>
    <blockquote>2014-05-30T05:57:24.002+0000: 32724.998: [Full
      GC32726.138: [SoftReference, 154 refs, 0.0050380 secs]32726.143:
      [WeakReference, 7713339 refs, 0.3449380 secs]32726.488:
      [FinalReference, 1966941 refs, 0.1005860 secs]32726.588:
      [PhantomReference, 650797 refs, 0.0631680 secs]32726.652: [JNI
      Weak Reference, 0.0000060 secs] [PSYoungGen:
      1012137K->0K(14784384K)] [ParOldGen:
      16010001K->5894387K(16384000K)]
      17022139K->5894387K(31168384K) [PSPermGen:
      39256K->39256K(39552K)], 4.3463290 secs] [Times: user=98.05
      sys=0.00, real=4.35 secs] <br>
    </blockquote>
    While the throughput collector spent 0.34 seconds processing 7.7
    million weak references<br>
    <br>
    <br>
    In summary, the G1 collector processed weak references at a rate of
    1.27 million per second, while the throughput collector processed
    them at 22.36 million references per second. Is there a fundamental
    design reason that explains why the G1 collector should be so much
    slower in this regard, or might there be ways to improve upon it?<br>
    <br>
    <br>
    Jason<br>
  </body>
</html>