循环大量数据导致内存超出,不增加内存如何解决该问题
我在生成HTML文件时,由于数据量较大,无数次的 fopen fwrite fclose,文件还没生成完呢,就提示内存超出。
我的HTML生成方式是,读入缓存,再写入文件
ob_start (); $temp = ob_get_contents (); ob_end_clean ();
我unset(temp) 也不起作用,这个问题到底该怎么解决。不知那些CMS又是怎么生成HTML的,再大的数据也不会内存超出
回复讨论(解决方案)
不知道你的具体代码,不好说什么
需要及时释放工作变量,可将工作放在函数中执行,以利用 php 自己的回收机制
自己释放变量时需注意的是数组占用的内存是只增不减的,所以要注意数组的复用
我在生成HTML文件时,由于数据量较大,无数次的 fopen fwrite fclose,文件还没生成完呢,就提示内存超出。
我的HTML生成方式是,读入缓存,再写入文件
ob_start (); $temp = ob_get_contents (); ob_end_clean ();
我unset(temp) 也不起作用,这个问题到底该怎么解决。不知那些CMS又是怎么生成HTML的,再大的数据也不会内存超出
比如某个脚本为必须为死循环,那么循环到一定次数就会造成内存超出,如何控制每循环100次,释放内存
那你加个循环控制量就是了
PHP生成HTML,怎样才能让他内存不超出,求代码
周末休息没人回答了
我在生成HTML文件时,由于数据量较大,无数次的 fopen fwrite fclose,文件还没生成完呢,就提示内存超出。
我的HTML生成方式是,读入缓存,再写入文件
ob_start(); $temp = ob_get_contents (); ob_end_clean ();
我unset(temp) 也不起作用,这个问题到底该怎么解决。不知那些CMS又是怎么生成HTML的,再大的数据也不会内存超出
比如某个脚本为必须为死循环,那么循环到一定次数就会造成内存超出,如何控制每循环100次,释放内存
$p = $_GET['p'] * 100; for($i=$p; $i<$p+100; $i++){ e cho $i; echo '<br>'; // ..... // 执行其他操作 }sleep(1); ?> <script> var p = GetQueryString('p'); p++;var url = window.location.href; var new_url = url.replace(/\?p=(\d)+/, '') + '?p=' + p; window.location.href = new_url; function GetQueryString(name){ var reg = new RegExp("(^|&)"+ name +"=([^&]*)(&|$)"); var r = window.location.search.substr(1).match(reg); if(r!=null)return unescape(r[2]); return null;} </script>
思路就是把大任务分批执行
用分页读取的方式。
加:register_shutdown_function
每页写完,自动header location到下一页。
用register_shutdown_function 的话,只要你打开了第一次,就可以关闭浏览器了,它会自动执行。
数据的最后一页写完了,要执行:die();
这种情况要分批执行,上个代码,你马上就明白其中的原理了
$total = 10;$s = 0; if (isset ( $_GET ['s'] )) { $s = &$_GET ['s']; }$per = $s + 5; // 每次循环5条if ($per > $total) { // 如果下次循环会超过总数,就让他只能循环到总数 $per = &$total;}while ( $s < $per ) { echo ++ $s; echo '<br>'; } echo '<hr>'; echo $s;if ($s < $total) { echo "<script>window.location.href='?s=$s'</script>"; }

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics



Alipay PHP...

JWT is an open standard based on JSON, used to securely transmit information between parties, mainly for identity authentication and information exchange. 1. JWT consists of three parts: Header, Payload and Signature. 2. The working principle of JWT includes three steps: generating JWT, verifying JWT and parsing Payload. 3. When using JWT for authentication in PHP, JWT can be generated and verified, and user role and permission information can be included in advanced usage. 4. Common errors include signature verification failure, token expiration, and payload oversized. Debugging skills include using debugging tools and logging. 5. Performance optimization and best practices include using appropriate signature algorithms, setting validity periods reasonably,

Article discusses late static binding (LSB) in PHP, introduced in PHP 5.3, allowing runtime resolution of static method calls for more flexible inheritance.Main issue: LSB vs. traditional polymorphism; LSB's practical applications and potential perfo

Article discusses essential security features in frameworks to protect against vulnerabilities, including input validation, authentication, and regular updates.

The article discusses adding custom functionality to frameworks, focusing on understanding architecture, identifying extension points, and best practices for integration and debugging.

Sending JSON data using PHP's cURL library In PHP development, it is often necessary to interact with external APIs. One of the common ways is to use cURL library to send POST�...

The application of SOLID principle in PHP development includes: 1. Single responsibility principle (SRP): Each class is responsible for only one function. 2. Open and close principle (OCP): Changes are achieved through extension rather than modification. 3. Lisch's Substitution Principle (LSP): Subclasses can replace base classes without affecting program accuracy. 4. Interface isolation principle (ISP): Use fine-grained interfaces to avoid dependencies and unused methods. 5. Dependency inversion principle (DIP): High and low-level modules rely on abstraction and are implemented through dependency injection.

Session hijacking can be achieved through the following steps: 1. Obtain the session ID, 2. Use the session ID, 3. Keep the session active. The methods to prevent session hijacking in PHP include: 1. Use the session_regenerate_id() function to regenerate the session ID, 2. Store session data through the database, 3. Ensure that all session data is transmitted through HTTPS.
