您好,登錄后才能下訂單哦!
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.
那么這個時候怎么解決呢?
1. 修改session.save_path,或使用session_save_path()讓每個站點的session保存到一個專用目錄,
2. 提供GC的啟動率,自然,GC的啟動率提高,系統的性能也會相應減低,不推薦。
3. 在代碼中判斷當前session的生存時間,利用session_destroy()刪除.
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。