① 一次php內存溢出的解決及思考
這個報錯在php報錯司空見慣,就是memory_limti值超出了限制導致的報孝簡老錯,簡單粗暴不負責任就是改php.ini設置,或者稍微好點就是init_set("memory_limit","2048M"),但是這兩種都是治標不治本,沒有從根本上解決這個報錯,如果數據20萬通過改memory_limit可以稍微控制,但是50萬,100萬咧這樣巧升就是無限的咐轎擴大這個值導致伺服器隨時出現問題。
② php 的位運算總結
php的位運算很少會用到,但是用處很大,
在有些演算法中會用到,在許可權管理中也會經常用到,
對於理解計算機的世界也會有一定的幫助,所以得把這些重要但不常用的東西總結一下記錄一下。
提到位運算,避不開的是二進制。
因為位運算是直接在內存做操作和運算,相較與直接拿兩個變數做運算符肯定是更快的。
很多地方把二進制這玩意說得很晦澀,現在來以最簡單的方式來總結一下,當然只算 int 范圍內的數算了,超過了這個范疇程序員還不如拿這時間去學點別的。
說完以上總結,再來解釋下什麼是二進制,網上大把,
但只要記住,int范圍內的數也就是我們大部分需要用到的數,都可以用二進制來表示。
我們生活中用到的計數方式為十進制,由個數位滿10進1,
然後再開始重新計算,等十位滿9再加一時,百位加一,十位歸零。
二進制則只有兩個數字來表示就是0和1,滿2進1。
由32個位組成,雖然只有32個位但已滿足了我們正常的需求了
比如說1轉換為2進制原碼,由於1是正數所以符號位為0,
原碼反碼補碼都一個樣。
1的原碼:00000000 00000000 00000000 00000001
因手懶,太多0太丑用+拼接,Ɔ* 8'代表8個0
2的原碼:0* 8 0* 8 0* 8 0* 6 + 1 0,既然是二進制,
滿2就得進1,最低位歸0,向前加一。
再來解釋下負數的原碼反碼和補碼,就開始講php的位運算了。
二進制復習完畢。下面開始講講php的位運算。
php一共有六種位運算,一種一種來講。
可以這么理解,兩個數的補碼放在一起比較每個位(一共32個位),
可以得出另外一個數,這個數字的組成由比較的兩位數字生成,
如果兩個數的每個位數上的數字都等於1的話,
那得到的那個數的補碼的同位為1,否則為0。
聽著繞口,其實很簡單,覺得還是比官網上的更容易讓新手看懂
下面舉例子:
首先來求-1和7的補碼。7的原碼就是補碼。
兩個補碼都有了下面開始運算:
按照上面的說法, 每個位都有一樣則 $a 的同等位則為1,剛好-1的補碼和7的補碼前面都不一樣,就最後三位一樣,所以剛好求得的 $a 的補碼的最後三位是1而其他的都是0 ,剛好這個補碼為正數,正好就是7。
其實就是和按位與相反,只要有1個為1,那就為1,如果都不為1,那就為0。
$a = -1|7 ;得出來的 $a 補碼為32個1,但此時不能說 $a 就是-1,因為這只是補碼,要轉成原碼再轉成十進制數,補碼-1,然後再翻轉,再轉出來,得到的其實也還是-1。
就是將這個數的補碼全部翻轉過來,包括符號位,0變1,1變0
取反的結果一定是整數變負數負數變正數,取正數的反時,
記得一定要從補碼一步步轉到原碼再轉成十進制數才是答案。
兩個數的補碼比較,同等位上的兩數比較
,不一樣時,則答案的補碼的同位則為1,否則為0。
往左移符號位被擠走右邊0補充,往右移動,符號位不動,
高位以符號位補充。二進制世界裡往左移動其實是相當於乘以了2,
右移相當於除以了2。
不吹牛逼的說,這應該是互聯網上最容易理解的php位運算的解釋和二進制的解釋了。
原文鏈接: php的位運算總結-PHP
③ 求助:PHP內存溢出問題Fatal error:Out of memory
程序源指扒雹昌裡面開始的時候加入:ini_set('memory_limit', '1024M');
或者你也可逗態以更改php.ini裡面的配置.
默認內存是128m.
④ 位運算有溢出嗎如何解決
當然有,0x80<<1就溢出了,溢出的值在程序狀態字的最高位CY裡面
⑤ php利用高階函數消除遞歸,解決遞歸棧溢出問題
微信小程序推送服務通知需要收集足夠的formid,使用過程中發現如果formid大量失效,在使用遞歸宏納從redis從獲取可用formid的時候會導致棧握拆溢出問題,下面方法是蔽皮沒使用php的高階函數來消除遞歸,完美解決問題,記錄之:
<?php
class A
{
public static function factorial($n, $accumulator = 1) {
if ($n == 0) {
return $accumulator;
}
return function() use($n, $accumulator) {
return self::factorial($n - 1, $accumulator * $n);
};
}
public static function trampoline($params) {
$result = call_user_func_array('self::factorial', $params);
while (is_callable($result)) {
$result = $result();
}
return $result;
}
public static function run()
{
var_mp(self::trampoline(array(500)));
}
}
A::run();
⑥ PHP 如何在64位系統讓32位的整型左移溢出
可以在64bit系統上把補碼處理一下
×手上沒裝64bit的php所以用java的64bit的long模擬
publicclassTest{
publicstaticvoidmain(String[]args){
inta=83661<<15;
System.out.println("32bit:"+a);
longn=83661L<<15;
System.out.println("64bit:"+n);
if(n>0x7fffffffL){
n--;n=~n;n&=0x7fffffffL;n=-n;
}
System.out.println("64bit處理後:"+n);
}
}
32bit:-1553563648
64bit:2741403648
64bit處理後:-1553563648
如不想移植以上的,PHP還可以直接把數值pack()打包成32bit有符號,再按32bit有符號unpack()一次也能得到需要的負數,不過感覺這樣效率不如以上直接計算快..
⑦ php 執行mysql中查詢時內存溢出怎麼辦
使用mysql_unbuffered_query(), 可以避免內存的立即佔用, 如果返回的結果存放到array中也是完全沒有問題的, 也不會出現php查詢mysql數據量過大時導致內存溢出問題.
這種情況一般會在單表數據表資料庫比較大的時候出現,建議在使用的過程中限制單次讀取數據條數,或者對數據表進行分表
⑧ phpExcel 輸出Excel 內存溢出
phpExcel 輸出Excel 內存溢出可以通過代碼來設置不同的緩存方式,已達到降低內存消耗的目的。
工具:office Excel
步驟:
1、將單元格數據序列化後保存在內存中。
代碼如下:
PHPExcel_CachedObjectStorageFactory::cache_in_memory_serialized;
2、將單元格序列化後再進行Gzip壓縮,然後保存在內存中。
代碼如下:
PHPExcel_CachedObjectStorageFactory::cache_in_memory_gzip;
3、緩存在臨時的磁碟文件中,速度可能會慢一些。需要耐心等待一會兒。
代碼如下:
PHPExcel_CachedObjectStorageFactory::cache_to_discISAM;
4、保存在php://temp。
代碼如下:
PHPExcel_CachedObjectStorageFactory::cache_to_phpTemp;
5、保存在memcache中。
代碼如下:
PHPExcel_CachedObjectStorageFactory::cache_to_memcache;
6、設置完成即可達到降低內存消耗的目的。
⑨ php內存溢出問題,求教大神!
你看看你的程序裡面有沒有用基基談到遞歸,或者有沒有死循環。
另外解決此類問題的主要思想就是分而治之
我覺得是foreach的機制的問題
foreach($arr as $key=>$value){}這裡面的$value是每次循環是把數組中元素的值賦值給$value
而foreach($arr as $key=>&$value){}這里的$value是引用賦值。
兩者有什麼區別呢?帶引用的$value可以$value='aaa';直接改變元素的值;還有一個重要的,就是最後一次循環之後$value的值還會保留;
你這里是foreach($obj as $value){}對象默認是搏碰引用傳值;所以循環過後要unset($obj);
php里還有一個函數clearstatcache(true)清楚文件狀態緩存,雖然受影響的函數沒有simplexml_load_file(),不過還是可以試試;
還有mysql系列的函數很多也不是很穩定,有時候不知道會出什麼問題;建議用PDO;
深鋒尺感php裡面的坑太多了,稍不注意就跳進去了。
⑩ php位運算
PHP只有編譯的時候能在make configure參數裡面設置嫌並整型是32 還是64bit。
win的64bit版的php也是32bit整型,和linux不同。
linux下64bit版的PHP就是64bit整型,只有這種特鉛者明殊情況。
64bit整型需要多對位運算環節中的
每次超32bit情況進行溢出捨去的處理。。處理後的槐告演算法是可以32/64通用的