PHP5.3新特性介紹
Namespacesphp 5.3最大的改動(dòng),毫無疑問就是Namespaces(此前有一篇相關(guān)的PHP Namespaces FAQ)。這給php開發(fā)人員帶來的好處不少,廣為人們所詬病的函數(shù)命名問題也得到了解決。
代碼更清晰5.3之前常見的代碼,需要自定義前綴區(qū)分函數(shù)和類名
PLAIN TEXT
CODE:
function MY_wrapper() {}class MY_DB { }define('MY_CONN_STR', '');MY_wrapper();new MY_DB();MY_CONN_STR;
使用名稱空間之后,代碼看上去更加clean。
PLAIN TEXT
CODE:
namespace MY;function wrapper() {}class DB { }const CONN_STR = '';use MY AS MY;wrapper();new DB();CONN_STR;一個(gè)文件中定義了多個(gè)namespace如果一個(gè)文件中定義了多個(gè)namespace,應(yīng)該怎樣處理?
PLAIN TEXT
CODE:
namespace LIB;class MySQL {}class SQLite {}$b = new SQLite();namespace LIB_EXTRA;class MScrypt {}$a = new MScrypt();var_dump( get_class($a), get_class($b));以上代碼輸出為:
PLAIN TEXT
CODE:
string(18)'LIB_EXTRA::MScrypt'string(11)'LIB::SQLite'php是解釋執(zhí)行的語(yǔ)言,以上結(jié)果合情合理。
namespace的優(yōu)先級(jí)namespace中定義的函數(shù),類和常量?jī)?yōu)先,其次才是全局的。
PLAIN TEXT
CODE:
namespace foo;function strlen($foo) { return htmlentities($foo); }echo strlen('test'); // test echo ::strlen('test'); // 4echo namespace::strlen('test'); // testnamespace和autoload的友情autoload會(huì)根據(jù)namespace名稱以及class名稱來解析類文件位置僅當(dāng)namespace和全局范圍都沒找到class定義的情況下,autoload才會(huì)被觸發(fā)在namespace中定義的__autoload不會(huì)被自動(dòng)調(diào)用PLAIN TEXTCODE:function __autoload($var) { var_dump($var); } // LIB::foorequire './ns.php'; /* <?php namespace LIB; new foo();*/namespace一些輔料PLAIN TEXT
CODE:
namespace really::long::pointlessly::verbose::ns__NAMESPACE__; // 新增的魔法常量,表示當(dāng)前namespace名稱class a{}get_class(new a()); // really::long::pointlessly::verbose::ns::ause really::long::pointlessly::verbose::ns::a AS b;// 從名稱空間中引用一個(gè)類注:這里的內(nèi)容節(jié)選自pdfIntroduction to PHP 5.3 Slides,后文不再?gòu)?fù)述。
性能提升php 5.3的總體性能提升了5 - 15%
md5()快了10-15%Better stack implementation in the engineConstants移到read-only內(nèi)存里exception處理過程改進(jìn)(簡(jiǎn)化,opcodes更少)(require/include)_once改進(jìn),去掉重復(fù)openSmaller binary size & startup size with gcc4新語(yǔ)言特性__DIR__在5.3以前,為了獲得當(dāng)前腳本的目錄,需要一次函數(shù)調(diào)用
PLAIN TEXT
CODE:
echo dirname(__FILE__); // < PHP 5.3
在5.3,只需要一個(gè)魔術(shù)常量__DIR__就解決了。
PLAIN TEXT
CODE:
echo __DIR__; // >= PHP 5.3?:操作符便捷的?:操作符,可以從兩個(gè)值/表達(dá)式中快速取得非空值。
PLAIN TEXT
CODE:
$a = true ?: false; // true$a = false ?: true; // true$a = '' ?: 1; // 1$a = 0 ?: 2; // 2$a = array() ?: array(1); // array(1);$a = strlen('') ?: strlen('a'); // 1__callStatic()新增了魔術(shù)方法__callStatic,功能和__call類似,但是僅對(duì)static方法有效。
PLAIN TEXT
CODE:
class helper { static function __callStatic($name, $args) { echo $name.'('.implode(',', $args).')'; }}helper::test('foo','bar'); // test(foo,bar)動(dòng)態(tài)調(diào)用static方法動(dòng)態(tài)的調(diào)用靜態(tài)方法?動(dòng)靜結(jié)合。
PLAIN TEXT
CODE:
class helper { static function foo() { echo __METHOD__; }}$a = 'helper';$b = 'foo';$a::$b(); // helper::fooLate Static Binding不知道怎么譯,可能留個(gè)原文更容易理解。靜態(tài)方法的事件處理時(shí)機(jī)有變化,以前是在編譯期處理,現(xiàn)在是執(zhí)行期間處理。
在php 5.3之前,下面的代碼會(huì)輸出一個(gè)A,但是這不是咱們要的,whoami方法已經(jīng)在class B中重新定義,它本該輸出B才符合咱們想當(dāng)然的思維。
PLAIN TEXT
CODE:
class A { public static function whoami() { echo __CLASS__; } public static function identity() { self::whoami(); }}class B extends A { public static function whoami() { echo __CLASS__; }}B::identity(); // A <-- PHP <5.3下面代碼中使用了static::whoami()來調(diào)用靜態(tài)方法。php 5.3之后,由于__CLASS__是在執(zhí)行期被處理,那么這個(gè)例子中能順利抓到class B。
PLAIN TEXT
CODE:
class A { public static function whoami() { echo __CLASS__; } public static function identity() { static::whoami(); }}class B extends A { public static function whoami() { echo __CLASS__; }}B::identity(); // B <-->= PHP 5.3mysqlnd見mysqlnd成為php 5.3中的默認(rèn)mysql驅(qū)動(dòng)
但是PDO_MySQL暫時(shí)還不支持mysqlnd,目前只有mysql(i)擴(kuò)展可以用到
之前介紹的php 5.3的新特性,都是方便開發(fā)人員的東東。下面介紹個(gè)很討虛擬主機(jī)提供商喜歡的特性。
增強(qiáng)的ini文件支持CGI/ FastCGI支持類似.htaccess的INI配置每個(gè)目錄下都可以有INI設(shè)置,ini的文件名取決于php.ini的配置,但是[PATH=/var/www/domain.com], [HOST=www.domain.com]段落的設(shè)置用戶不能修改。增強(qiáng)的error handling允許在ini文件中定義變量和常量,可以在程序中直接調(diào)用。附上一段ini文件的例子
PLAIN TEXT
CODE:
#用戶自定義的php.ini文件名(.htaccess). 默認(rèn)是'.user.ini'user_ini.filename='.user.ini'#如果要禁用這個(gè)特性,設(shè)置為空值即可user_ini.filename=#用戶自定義的php.ini文件TTL時(shí)長(zhǎng)(time-to-live),單位為秒,我理解為緩存過期時(shí)間。默認(rèn)為300秒user_ini.cache_ttl=300[PATH=/var/www/domain.com]variables_order = GPCsafe_mode =1[my variables]somevar = “1234”anothervar = ${somevar}; anothervar == somevar[ini arrays]foo[bar]=1foo[123]=2foo[]=3
