PHP中使用unset銷毀變數並記憶體釋放問題

2022-10-04 10:09:09 字數 4446 閱讀 5954

複製** **如下:

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...