通常來說,如果PHP對象存在遞歸引用,就會出現內存洩漏。這個Bug在PHP裡已經存在很久很久了,先讓我們來重現這個Bug,示例代碼如下:
<?php class Foo { function __construct() { $this->bar = new Bar($this); } } class Bar { function __construct($foo) { $this->foo = $foo; } } for ($i = 0; $i < 100; $i++) { $obj = new Foo(); unset($obj); echo memory_get_usage(), "/n"; } ?>
運行以上代碼,你會發現,內存使用量本應該不變才對,可實際上卻是不斷增加,unset沒有完全生效。
現在的開發很多都是基於框架進行的,應用裡存在復雜的對象關系,那麼就很可能會遇到這樣的問題,下面看看有什麼權宜之計:
<?php class Foo { function __construct() { $this->bar = new Bar($this); } function __destruct() { unset($this->bar); } } class Bar { function __construct($foo) { $this->foo = $foo; } } for ($i = 0; $i < 100; $i++) { $obj = new Foo(); $obj->__destruct(); unset($obj); echo memory_get_usage(), "/n"; } ?>
辦法有些丑陋,不過總算是對付過去了。幸運的是這個Bug在PHP5.3的CVS代碼中已經被修復了。
對此,在進行PHP程序設計時有必要加以注意!相信本文所述對大家的PHP程序設計有一定的參考價值。
函數demo有兩個必然的輸出語句,一個是開始的一個,一個是最後的一個!
函數運行流程
1.輸出num
2.判斷num大於0否從而確定是否調用函數
3.輸出num
在num大於0時,每一次調用函數,都只執行到第2步,後等待第二步調用自身返回結果後繼續執行,因此,每次調用自身結束返回後都重新輸出一次num,也就是倒序輸出了後面的數值!
那好吧 隨便啰嗦幾句
寫sql語句的時候 最好把mysql函數都大寫 這樣的話sql語句就一目了然 很好看的說。
比如:$sql = "SELECT * FROM `user` WHERE `id` = '$id'";
並且 表名 字段名都使用 ` 1旁邊的點(英文輸入法下的點)包含起來 並且給字段復制的變量 無論是字符串還是數字類型 都用' 單引號包含起來
可是很有好處的哦。。。。。