オブジェクト(いくつかの配列が作成される場所)を作成するループを実行し、その後ループ内で設定を解除します:
private function _runLoop($amountPerStep = 4){
$steps = floor(count($this->_symbolRows)/$amountPerStep);
$echo = "";
for($i = 0; $i <= $steps; $i++){
$tempSymbolRows = array_slice($this->_symbolRows,$i*$amountPerStep,($i+1)*$amountPerStep);
if (count($tempSymbolRows) == 0) continue;
$tempSymbols = array();
for($j = 0; $j < count($tempSymbolRows); $j++){
$tempSymbols[] = $tempSymbolRows[$j][0];
}
$scrapping = new Scraping($tempSymbols);
$echo .= "<pre>";
$echo .= "memory_peak_usage / memory_usage <br/>";
$echo .= memory_get_peak_usage()/1000000 ." / ". memory_get_usage() / 1000000 ."<br/><br/>";
//print_r($scrapping->getArrays());
$echo .= "</pre>";
$scrapping = NULL;
unset($scrapping);
gc_collect_cycles();
if( $i >= 3 ) break;
}
echo $echo;
}
3回目のループでの実行後、ループを破ります(テスト目的)。ループの配列を印刷する行をコメントアウトしました。これは、印刷用の配列を保存することでメモリを消費するためです (オブジェクトが存在しなくても)。それが問題だろうと思った。しかし、ループを実行すると、この出力が得られます
memory_peak_usage / memory_usage
7.805928 / 1.530504
memory_peak_usage / memory_usage
9.723464 / 6.28792
memory_peak_usage / memory_usage
39.414088 / 17.227368
memory_peak_usage / memory_usage
55.541584 / 23.166608
そのため、使用メモリサイズがどんどん大きくなっています...どこが間違っていますか? gc がリソースを解放しないのはなぜですか?