php5.3的新特性总结

Namespaces
php 5.3最大的改动,毫无疑问就是Namespaces(此前有一篇相关的PHP Namespaces FAQ)。这给php开发人员带来的好处很多,广为人们所诟病的函数命名问题也获得了解决。php

代码更清晰
5.3以前常见的代码,须要自定义前缀区分函数和类名html

PLAIN TEXTmysql

CODE:sql

function MY_wrapper() {}
class MY_DB { }
define('MY_CONN_STR', '');
MY_wrapper();
new MY_DB();
MY_CONN_STR;
 缓存

使用名称空间以后,代码看上去更加clean。app

PLAIN TEXTless

CODE:dom

namespace MY;
function wrapper() {}
class DB { }
const CONN_STR = '';
use MY AS MY;
wrapper();
new DB();
CONN_STR;
一个文件中定义了多个namespace
若是一个文件中定义了多个namespace,应该怎样处理?ide

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是解释执行的语言,以上结果合情合理。

namespace的优先级
namespace中定义的函数,类和常量优先,其次才是全局的。

PLAIN TEXT

CODE:

namespace foo;
function strlen($foo) { return htmlentities($foo); }
echo strlen("test"); // test
echo ::strlen("test"); // 4
echo namespace::strlen("test"); // test
namespace和autoload的友情
autoload会根据namespace名称以及class名称来解析类文件位置
仅当namespace和全局范围都没找到class定义的状况下,autoload才会被触发
在namespace中定义的__autoload不会被自动调用
PLAIN TEXT
 
CODE:
function __autoload($var) { var_dump($var); } // LIB::foo
require "./ns.php"; /*
        <?php
                namespace LIB;
                new foo();
*/
namespace一些辅料
PLAIN TEXT

CODE:

namespace really::long::pointlessly::verbose::ns; 
__NAMESPACE__; // 新增的魔法常量,表示当前namespace名称
class a{}  
get_class(new a()); // really::long::pointlessly::verbose::ns::a
use really::long::pointlessly::verbose::ns::a AS b;// 从名称空间中引用一个类
注:这里的内容节选自pdfIntroduction to PHP 5.3 Slides,后文再也不复述。

性能提高
php 5.3的整体性能提高了5 - 15%

md5()快了10-15%
Better stack implementation in the engine
Constants移到read-only内存里
exception处理过程改进(简化,opcodes更少)
(require/include)_once改进,去掉重复open
Smaller binary size & startup size with gcc4
新语言特性__DIR__
在5.3之前,为了得到当前脚本的目录,须要一次函数调用

PLAIN TEXT

CODE:

echo dirname(__FILE__); // < PHP 5.3
 

在5.3,只须要一个魔术常量__DIR__就解决了。

PLAIN TEXT

CODE:

echo __DIR__; // >= PHP 5.3
?:操做符
便捷的?:操做符,能够从两个值/表达式中快速取得非空值。

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()
新增了魔术方法__callStatic,功能和__call相似,可是仅对static方法有效。

PLAIN TEXT

CODE:

class helper {
        static function __callStatic($name, $args) {
                echo $name.'('.implode(',', $args).')';
        }
}
helper::test("foo","bar"); // test(foo,bar)
动态调用static方法
动态的调用静态方法?动静结合。

PLAIN TEXT

CODE:

class helper {
        static function foo() { echo __METHOD__; }
}
$a = "helper";
$b = "foo";
$a::$b(); // helper::foo
Late Static Binding
不知道怎么译,可能留个原文更容易理解。静态方法的事件处理时机有变化,之前是在编译期处理,如今是执行期间处理。

在php 5.3以前,下面的代码会输出一个A,可是这不是我们要的,whoami方法已经在class B中从新定义,它本该输出B才符合我们想固然的思惟。

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()来调用静态方法。php 5.3以后,因为__CLASS__是在执行期被处理,那么这个例子中能顺利抓到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.3
mysqlnd
见mysqlnd成为php 5.3中的默认mysql驱动

可是PDO_MySQL暂时还不支持mysqlnd,目前只有mysql(i)扩展能够用到

以前介绍的php 5.3的新特性,都是方便开发人员的东东。下面介绍个很讨虚拟主机提供商喜欢的特性。

加强的ini文件支持
CGI/ FastCGI支持相似.htaccess的INI配置
每一个目录下均可以有INI设置,ini的文件名取决于php.ini的配置,可是[PATH=/var/www/domain.com], [HOST=www.domain.com]段落的设置用户不能修改。
加强的error handling
容许在ini文件中定义变量和常量,能够在程序中直接调用。
附上一段ini文件的例子

PLAIN TEXT

CODE:

#用户自定义的php.ini文件名(.htaccess). 默认是".user.ini"user_ini.filename=".user.ini" #若是要禁用这个特性,设置为空值便可user_ini.filename= #用户自定义的php.ini文件TTL时长(time-to-live),单位为秒,我理解为缓存过时时间。默认为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

相关文章
相关标签/搜索