php5中魔術方法函數:
__construct():執行個體化對象時被調用;
__destruct():當删除一個對象或者對象操作終止是被執行;
__call():調用對象不存在方法時被調用;
__get(): 調用對象不存在的屬性時被調用;
__set():設定對象不存在的屬性時被調用;
__toString(): 列印一個對象時被調用,比如echo $obj;print($obj);
__clone(): 克隆對象時被調用,比如 $t = new Test();$tt = clone $t;
__sleep(): serialize之前被調用,若對象比較大,想做一些删除序列化,可以考慮使用該方法;
__wakeup(): unserialize之前被調用,做些對象的初始化;
__isset(): 檢測對象是否存在屬性的時候被調用,如isset($c->name);
__unset(): unset一個對象屬性時被調用,如unset($c->name);
__set_state():調用var_export是被調用,用__set_state的傳回值作為var_export的傳回值。
__autoload():執行個體化一個對象時,如果對應的類不存在,在該方法被調用。
php 寫一段代碼,確定多個程序同時寫入一個檔案成功
<?php
function writefile( $filename, $data ){
$fp = fopen( $filepath, 'a' ); //以追加的方式打開檔案,傳回的是指針
do{
usleep( 100 ); //暫停執行程式,參數是以微秒為機關的
}while( !flock( $fp, LOCK_EX ) ); //以獨享寫入的方式鎖定檔案,成功則傳回TRUE,否則FALSE
$res = fwrite( $fp, $data."/n" ); // 以追加的方式寫入資料到打開的檔案
flock( $fp, LOCK_UN ); //解鎖,以讓别的程序進行鎖定
fcloce( $fp ); //關閉打開的檔案指針
return $res;
} //傳回寫入結果
?>
php的垃圾回收機制
1、 在php中,沒有任何變量指向這個對象時,這個對象就會成為垃圾。php會将其在記憶體中銷毀;這是php的GC垃圾處理機制,防止記憶體溢出。
當一個PHP線程結束時,目前占用的所有記憶體空間都會被銷毀,目前程式中所有對象同時被銷毀。GC程序一般都跟着每起一個SESSION而開始運作的,GC目的是為了在session檔案過期以後自動銷毀删除這些檔案
2、 __destruct /unset
__destruct() 析構函數,是在垃圾對象被回收時執行。
unset 銷毀的是指向對象的變量,而不是這個對象。
3、 Session 與 GC
由于PHP的工作機制,它并沒有一個daemon線程來定期的掃描Session資訊并判斷其是否失效,當一個有
效的請求發生時,PHP 會根據全局變量
session.gc_probability和session.gc_divisor的值,來決定是否啟用一個GC,
在預設情況下,session.gc_probability=1, session.gc_divisor
=100也就是說有1%的可能性啟動GC(也就是說100個請求中隻有一個gc會伴随100個中的某個請求而啟動).
GC的工作就是掃描所有的Session資訊,用目前時間減去session最後修改的時間,同session.gc_maxlifetime參數進行比較,如果生存時間超過gc_maxlifetime(預設24分鐘),就将該session删除。
但是,如果你Web伺服器有多個站點,多個站點時,GC處理session可能會出現意想不到的結果,原因就是:GC在工作時,并不會區分不同站點的session.