複製** **如下:
for ( $i = 1; $i < 100; $i++ )
從結果看出:
8 x 32 = 256 在256位元組長的時候才真正有必要釋放記憶體,有些人說,不如直接$str = null來的速度快。
結果如下:
1: 0 bytes.
2: 0 bytes.
3: 0 bytes.
4: 0 bytes.
5: 0 bytes.
6: 0 bytes.
7: 0 bytes.
8: 0 bytes.
9: 0 bytes.
10: 0 bytes.
11: 0 bytes.
12: 0 bytes.
13: 0 bytes.
14: 0 bytes.
15: 0 bytes.
16: 0 bytes.
17: 0 bytes.
18: 0 bytes.
19: 0 bytes.
20: 0 bytes.
21: 0 bytes.
22: 0 bytes.
23: 0 bytes.
24: 0 bytes.
25: 0 bytes.
26: 0 bytes.
27: 0 bytes.
28: 0 bytes.
29: 0 bytes.
30: 0 bytes.
31: 0 bytes.
32: -272 bytes.
33: -280 bytes.
34: -288 bytes.
35: -296 bytes.
36: -304 bytes.
37: -312 bytes.
38: -320 bytes.
39: -328 bytes.
40: -336 bytes.
41: -344 bytes.
42: -352 bytes.
43: -360 bytes.
44: -368 bytes.
45: -376 bytes.
46: -384 bytes.
47: -392 bytes.
48: -400 bytes.
49: -408 bytes.
50: -416 bytes.
51: -424 bytes.
52: -432 bytes.
53: -440 bytes.
54: -448 bytes.
55: -456 bytes.
56: -464 bytes.
57: -472 bytes.
58: -480 bytes.
59: -488 bytes.
60: -496 bytes.
61: -504 bytes.
62: -512 bytes.
63: -520 bytes.
64: -528 bytes.
65: -536 bytes.
66: -544 bytes.
67: -552 bytes.
68: -560 bytes.
69: -568 bytes.
70: -576 bytes.
71: -584 bytes.
72: -592 bytes.
73: -600 bytes.
74: -608 bytes.
75: -616 bytes.
76: -624 bytes.
77: -632 bytes.
78: -640 bytes.
79: -648 bytes.
80: dzbsvfwtau-656 bytes.
81: -664 bytes.
82: -672 bytes.
83: -680 bytes.
84: -688 bytes.
85: -696 bytes.
86: -704 bytes.
87: -712 bytes.
88: -720 bytes.
89: -728 bytes.
90: -736 bytes.
91: -744 bytes.
92: -752 bytes.
93: -760 bytes.
94: -768 bytes.
95: -776 bytes.
96: -784 bytes.
97: -792 bytes.
98: -800 bytes.
99: -808 bytes.
我們先看乙個例子
複製** **如下:
php
$s=str_repeat('1',255); //產生由255個1組成的字串
$m=memory_get_usage(); //獲取當前占用記憶體
unset($s);
$mm=memory_get_usage(); //unset()後再檢視當前占用記憶體
echo $m-$mm;
?>
最後輸出unset()之前占用記憶體減去unset()之後占用記憶體,如果是正數,那麼說明unset($s)已經將$s從內程式設計客棧存中銷毀(或者說,unset()之後記憶體占用減少了),可是我在php5和windows平台下,得到的結果是:-48。這是否可以說明,unset($s)並沒有起到銷毀變數$s所占用記憶體的作用呢?我們再作下面的例子:
複製** **如下:
<?php
$s=str_repeat('1',256); //產生由256個1組成的字串
$m=memory_get_usage(); //獲取當前占用記憶體
unset($s);
$mm=memory_get_usage(); //unset()後再檢視當前占用記憶體
echo $m-$mm;
?>
這個例子,和上面的例子幾乎相同,唯一的不同是,$s由256個1組成,即比第乙個例子多了乙個1,得到結果是:224。這是否可以說明,unset($s)已經將$s所占用的記憶體銷毀了?
通過上面兩個例子,我們可以得出以下結論:結論一、unset()函式只能在變數值占用記憶體空間超過256位元組時才會釋放記憶體空間。
那麼是不是只要變數值超過256,使用unset就可以釋放記憶體空間呢?我們再通過乙個例子來測試一下:
複製** **如下:
<?php
$s=str_repeat('1',256); //這和第二個例子完全相同
$p=&$s;
$m=memory_get_usage();
unset($s); //銷毀$s
$mm=m程式設計客棧emory_get_usage();
echo $p.'
'; echo $m-$mm;
?>
'重新整理頁面,我們看到第一行有256個1,第二行是-48,按理說我們已經銷毀了$s,而$p只是引用$s的變數,應該是沒有內容了,另外,unset($s)後記憶體占用卻比unset()前增加了!現在我們再做以下的例子:
複製** **如下:
<?php
$s=str_repeat('1',256); //這和第二個例子完全相同
$p=&$s;
$m=memory_get_usage();
$s=null; //設定$s為null
$mm=memory_get_usage();
echo $p.'
'; echo $m-$mm;
?>
現在重新整理頁面,我們看到,輸出$p已經是沒有內容了,unset()前後記憶體佔用量之差是224,即已經清除了變數占用的記憶體。本例中的$s=null也可以換成unset(),如下:
複製** **如下:
<?php
$s=str_repeat('1',256); //這和第二個例子完全相同
$p=&$s;
$m=memory_get_usage();
unset($s); //銷毀$s
unset($p);
$mm=memory_get_usage();
echo $p.'
'; echo $m-$mm;
?>
我們將$s和$p都使用unset()銷毀,這時再看記憶體佔用量之差也是224,說明這樣也可以釋放記憶體。那麼,我們可以得到另外一條結論:結論
二、只有當指向該變數的所有變數(如引用變數)都被銷毀後,才會釋放記憶體。
本文標題: php中使用unset銷毀變數並記憶體釋放問題
本文位址: /wangluo/php/88317.html
php中使用unset銷毀變數並記憶體釋放
php的unset 函式用來清除 銷毀變數,不用的變數,我們可以用unset 將它銷毀。但是某些時候,用unset 卻無法達到銷毀變數占用的記憶體!php s str repeat 1 255 產生由255個1組成的字串 m memory get usage 獲取當前占用記憶體 unset s mm...
使用unset 銷毀變數並釋放記憶體
自 php的unset 函式用來清除 銷毀變數,不用的變數,我們可以用unset 將它銷毀。但是某些時候,用unset 卻無法達到銷毀變數占用的記憶體!我們先看乙個例子 s str repeat 1 255 產生由255個1組成的字串 m memory get usage 獲取當前占用記憶體 uns...
PHP isset 變數判斷和unset 銷毀
isset 檢查變數是否為空並且非null,變數為非空則會返回true,否則返回false 注意 一定情況下true會隱式的轉換為數字1,false一定情況下好轉換為數字0 所以有時候不一定返回true和false,而是返回1和0 unset 釋放 銷毀 變數 a 1 b null echo iss...