CRR (L / updated): 6888336: G1: avoid explicitly marking and pushing objects in survivor spaces

John Coomes John.Coomes at oracle.com
Thu Jan 12 01:16:51 UTC 2012


Tony Printezis (tony.printezis at oracle.com) wrote:
> Bengt,
> 
> Hi, thanks for looking at it! See inline.
> 
> On 01/10/2012 04:41 PM, Bengt Rutisson wrote:
> > ...
> > In  g1OopClosures.hpp you swapped the lines 151 and 152, which makes 
> > it look like this:
> >
> >  149   G1ParCopyClosure(G1CollectedHeap* g1, G1ParScanThreadState* 
> > par_scan_state,
> >  150                    ReferenceProcessor* rp) :
> >  151       G1ParCopyHelper(g1, par_scan_state, &_scanner),
> >  152       _scanner(g1, par_scan_state, rp) {
> >
> > I guess you want the call to the super class constructor before other 
> > initialization. To me it looks strange that the _scanner is passed to 
> > the super class, but is now actually not initialized until after the 
> > call to the super constructor. I would have preferred the order as it 
> > was before. I guess the new order works fine as long as the super 
> > constructor never tries to use the _scanner.
> 
> You're right. I wanted the constructor to be called first but I was 
> clearly a bit careless and I missed the dependency. Thanks for looking 
> at this carefully! Even though the dependency is benign here (the ref to 
> _scanner is only stored locally in the super class) I think we should 
> avoid and future surprises. So I'll undo the change.

I learned this the hard way:  the order you write it in the source
doesn't affect the initialization order.  The initialization order is
defined by the declaration order (i.e., superclasses are initialized
first in the order they appear in the class declaration, followed by
data members in the order they're declared in the class).

So the c++ compiler will call the G1ParCopyHelper ctor first, no
matter how you write it :-).

-John



More information about the hotspot-gc-dev mailing list