I guess that means that my bitvector technique will be of short-lived utility, but for now, it is doing sterling service for me.
That said, even if they manage to reduce the size of SV headers to 8 bytes (they'll still need the flags and type fields won't they?), then that still means that using a bitvector would only require 64 MB to handle a 32-bit/4GB address space and with many OS/32-bit processors, your restricted to 2GB anyway, so 32 MB max.
That's still way less than Data::Dumper currently uses for a 500 MB HoHoA which would only require < 8MB. Admittedly, D::D does do rather more than just detect self-refs which is all I need.
That said, the technique is so fast, that it wouldn't be a great burden doing two passes. The first simply sets the bits. The seconds then only need rcord the salient information for the refs that are self refs. The reduction in memory allocations may even achieve a time saving as well.
In reply to Re^4: Circular reference testing.
by BrowserUk
in thread Circular reference testing.
by BrowserUk
| For: | Use: | ||
| & | & | ||
| < | < | ||
| > | > | ||
| [ | [ | ||
| ] | ] |