0

オブジェクト(いくつかの配列が作成される場所)を作成するループを実行し、その後ループ内で設定を解除します:

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 がリソースを解放しないのはなぜですか?

4

1 に答える 1