perl自然会重用匿名数组的内存地址.如此示例所示,它们在两个地址之间循环以获取空数组:
$perl -E "say [] for (1..6)" ARRAY(0x37b23c) ARRAY(0x37b28c) ARRAY(0x37b23c) ARRAY(0x37b28c) ARRAY(0x37b23c) ARRAY(0x37b28c)
我想出了为什么它不能立即重新分配内存的一些理论,当我发现循环并不总是两个地址长.以下示例的循环为3和4.
$perl -E "say [0] for (1..6)" ARRAY(0x39b23c) ARRAY(0x39b2ac) ARRAY(0x39b28c) ARRAY(0x39b23c) ARRAY(0x39b2ac) ARRAY(0x39b28c) $perl -E "say [0,0] for (1..6)" ARRAY(0x64b23c) ARRAY(0x64b2cc) ARRAY(0x64b2ac) ARRAY(0x64b28c) ARRAY(0x64b23c) ARRAY(0x64b2cc)
是什么导致了内存管理的这种特性?
解决方法
当SV被释放时,它们实际上被放入“免费”池中.也许他们进入游泳池的顺序会影响他们退出的顺序.