>백엔드 개발 >PHP 튜토리얼 >PHPExcel 메모리 누수 해결 사례 공유

PHPExcel 메모리 누수 해결 사례 공유

*文
*文원래의
2017-12-25 13:52:451917검색

이 글에서는 주로 PHPExcel의 메모리 누수 문제에 대한 해결책을 소개합니다. 먼저 메모리 누수의 원인을 설명하고, 필요한 친구가 참고하면 됩니다.

PHPExcel을 사용하여 Excel 문서를 생성하면 더 많은 비용이 소모됩니다. 메모리 부족을 방지하기 위해 루프를 사용하여 대용량 데이터를 여러 개의 작은 Excel 문서로 나누어 저장해야 하는 경우도 있습니다.
그러나 PHPExcel에는 순환 참조가 있습니다(최신 1.6.5 버전에서는 아직 이 문제가 해결되지 않은 것 같습니다). 여러 Excel 문서 생성 작업을 완료하기 위해 http 요청 중에 PHPExcel 및 PHPExcel_Writer_Excel5 개체 인스턴스가 여러 번 반복적으로 생성되는 경우 , 구성된 모든 객체 인스턴스는 http 요청이 끝나기 전에 시간 내에 해제될 수 없으므로 메모리 누수가 발생합니다.
해결책은 PHPExcel_Worksheet 클래스에 메서드를 추가하는 것입니다:


 public function Destroy() {
     foreach($this->_cellCollection as $index => $dummy) {
         $this->_cellCollection[$index] = null;
     }
 }


PHPExcel 클래스에 메서드를 추가합니다:

 public function Destroy() {
     foreach($this->_workSheetCollection as $index => $dummy) {
         $this->_workSheetCollection[$index]->Destroy();
         $this->_workSheetCollection[$index] = null;
     }
 }


그런 다음 리소스 복구가 필요한 경우 PHPExcel::Destroy()를 명시적으로 호출합니다. 참조 문제. __destruct() 메서드는 객체가 해제될 준비가 된 것으로 간주될 때만 호출되므로 __destruct()에서는 순환 참조 처리를 수행할 수 없습니다.

관련 읽기:

Thinkphp5+PHPExcel은 테이블 data_php 예제를 일괄 업로드하는 기능을 구현합니다.

헤더를 고정하고 잠그는 PHPExcel 방법 소개

PHP 구현 Yii2 프레임워크 Excel 내보내기 Excel 파일을 공유하는 방법

위 내용은 PHPExcel 메모리 누수 해결 사례 공유의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.