#### php5.3 PHP5.4 PHP5.5 php5.6 新特性
用到PHP新版本,一些新特性必須要了解,有些可以在開發時就使用。
PHP7.0 和PHP7.1.X新特性請看 http://blog.csdn.net/fenglailea/article/details/52717364
#### 1.PHP 5.3中的新特性
##### 1.1 PHP 5.3中的新特性
###### 1.1.1 支持命名空間 (Namespace)
> 毫無疑問,命名空間是PHP5.3所帶來的最重要的新特性。在PHP5.3中,則只需要指定不同的命名空間即可,命名空間的分隔符為反斜桿\。
select.php
~~~
<?php
namespace Zend\Db\Table;
class Select {}
~~~
這樣即使其它命名空間下存在名為Select的類,程序在調用時也不會產生沖突。代碼的可讀性也有所增加。
調用方法 call.php
~~~
<?php
//namespace Zend\Db;
include('select.php');
$s = new Zend\Db\Table\Select();
$s->test();
~~~
###### 1.1.2 支持延遲靜態綁定(Late Static Binding)
在PHP5中,我們可以在類中通過self關鍵字或者__CLASS__來判斷或調用當前類。但有一個問題,如果我們是在子類中調用,得到的結果將是父類。因為在繼承父類的時候,靜態成員就已經被綁定了。 例如:
~~~
<?php
class A {
public static function who() {
echo __CLASS__;
}
public static function test() {
self::who();
}
}
class B extends A {
public static function who() {
echo __CLASS__;
}
}
B::test();
~~~
以上代碼輸出的結果是: A
這和我們的預期不同,我們原來想得到子類的相應結果。
PHP 5.3.0中增加了一個static關鍵字來引用當前類,即實現了延遲靜態綁定:
~~~
<?php
class A {
public static function who() {
echo __CLASS__;
}
public static function test() {
static::who(); // 這里實現了延遲的靜態綁定
}
}
class B extends A {
public static function who() {
echo __CLASS__;
}
}
B::test();
~~~
以上代碼輸出的結果是: B
###### 1.1.3 支持goto語句
多數計算機程序設計語言中都支持無條件轉向語句goto,當程序執行到goto語句時,即轉向由goto語句中的標號指出的程序位置繼續執行。盡管goto語句有可能會導致程序流程不清晰,可讀性減弱,但在某些情況下具有其獨特的方便之處,例如中斷深度嵌套的循環和 if 語句。
~~~
<?php
goto a;
echo 'Foo';
a:
echo 'Bar';
for($i=0,$j=50; $i<100; $i++) {
while($j--) {
if($j==17) goto end;
}
}
echo "i = $i";
end:
echo 'j hit 17';
~~~
###### 1.1.4 支持閉包、Lambda/Anonymous函數
閉包(Closure)函數和Lambda函數的概念來自于函數編程領域。例如JavaScript 是支持閉包和 lambda 函數的最常見語言之一。
在PHP中,我們也可以通過create_function()在代碼運行時創建函數。但有一個問題:創建的函數僅在運行時才被編譯,而不與其它代碼同時被編譯成執行碼,因此我們無法使用類似APC這樣的執行碼緩存來提高代碼執行效率。
在PHP5.3中,我們可以使用Lambda/匿名函數來定義一些臨時使用(即用即棄型)的函數,以作為array_map()/array_walk()等函數的回調函數。
~~~
<?php
echo preg_replace_callback('~-([a-z])~', function ($match) {
return strtoupper($match[1]);
}, 'hello-world');
// 輸出 helloWorld
$greet = function($name)
{
printf("Hello %s\r\n", $name);
};
$greet('World');
$greet('PHP');
//在某個類中
$callback = function ($quantity, $product) use ($tax, &$total) {
$pricePerItem = constant(__CLASS__ . "::PRICE_" . strtoupper($product));
$total += ($pricePerItem * $quantity) * ($tax + 1.0);
};
array_walk($products, $callback);
~~~
###### 1.1.5 新增兩個魔術方法__callStatic()和__invoke()
PHP中原本有一個魔術方法__call(),當代碼調用對象的某個不存在的方法時該魔術方法會被自動調用。新增的__callStatic()方法則只用于靜態類方法。當嘗試調用類中不存在的靜態方法時,__callStatic()魔術方法將被自動調用。
~~~
<?php
class MethodTest {
public function __call($name, $arguments) {
// 參數 $name 大小寫敏感
echo "調用對象方法 '$name' " . implode(' -- ', $arguments). "\n";
}
/** PHP 5.3.0 以上版本中本類方法有效 */
public static function __callStatic($name, $arguments) {
// 參數 $name 大小寫敏感
echo "調用靜態方法 '$name' " . implode(' -- ', $arguments). "\n";
}
}
$obj = new MethodTest;
$obj->runTest('通過對象調用');
// As of PHP 5.3.0
MethodTest::runTest('靜態調用');
~~~
以上代碼執行后輸出如下: 調用對象方法'runTest' –- 通過對象調用調用靜態方法'runTest' –- 靜態調用
以函數形式來調用對象時,__invoke()方法將被自動調用。
~~~
<?php
class MethodTest {
public function __call($name, $arguments) {
// 參數 $name 大小寫敏感
echo "Calling object method '$name' "
. implode(', ', $arguments). "\n";
}
/** PHP 5.3.0 以上版本中本類方法有效 */
public static function __callStatic($name, $arguments) {
// 參數 $name 大小寫敏感
echo "Calling static method '$name' "
. implode(', ', $arguments). "\n";
}
}
$obj = new MethodTest;
$obj->runTest('in object context');
// As of PHP 5.3.0
MethodTest::runTest('in static context');
~~~
###### 1.1.6. 新增Nowdoc語法
用法和Heredoc類似,但使用單引號。Heredoc則需要通過使用雙引號來聲明。
Nowdoc中不會做任何變量解析,非常適合于傳遞一段PHP代碼。
~~~
<?php
// Nowdoc 單引號 PHP 5.3之后支持
$name = 'MyName';
echo <<<'EOT'
My name is "$name".
EOT;
//上面代碼輸出 My name is "$name". ((其中變量不被解析)
// Heredoc不加引號
echo <<<FOOBAR
Hello World!
FOOBAR;
//或者 雙引號 PHP 5.3之后支持
echo <<<"FOOBAR"
Hello World!
FOOBAR;
~~~
支持通過Heredoc來初始化靜態變量、類成員和類常量。
~~~
<?php
// 靜態變量
function foo()
{
static $bar = <<<LABEL
Nothing in here...
LABEL;
}
// 類成員、常量
class foo
{
const BAR = <<<FOOBAR
Constant example
FOOBAR;
public $baz = <<<FOOBAR
Property example
FOOBAR;
}
~~~
###### 1.1.7. 在類外也可使用const來定義常量
~~~
//PHP中定義常量通常是用這種方式
define("CONSTANT", "Hello world.");
//并且新增了一種常量定義方式
const CONSTANT = 'Hello World';
~~~
###### 1.1.8 三元運算符增加了一個快捷書寫方式
原本格式為是(expr1) ? (expr2) : (expr3)
如果expr1結果為True,則返回expr2的結果。
`PHP5.3` 新增一種書寫方式,可以省略中間部分,書寫為expr1 ?: expr3
如果expr1結果為True,則返回expr1的結果
~~~
//原格式
$expr=$expr1?$expr1:$expr2
//新格式
$expr=$expr1?:$expr2
~~~
###### 1.1.9 HTTP狀態碼在200-399范圍內均被認為訪問成功
###### 1.1.10支持動態調用靜態方法
~~~
class Test{
public static function testgo()
{
echo "gogo!";
}
}
$class = 'Test';
$action = 'testgo';
$class::$action(); //輸出 "gogo!"
~~~
##### 1.2 PHP5.3中其它值得注意的改變
###### 1.2.1 修復了大量bug
###### 1.2.2 PHP性能提高
###### 1.2.3 php.ini中可使用變量
###### 1.2.4 mysqlnd進入核心擴展 理論上說該擴展訪問mysql速度會較之前的MySQL 和 MySQLi 擴展快(參見http://dev.mysql.com/downloads/connector/php-mysqlnd/)
###### 1.2.5 ext/phar、ext/intl、ext/fileinfo、ext/sqlite3和ext/enchant等擴展默認隨PHP綁定發布。其中Phar可用于打包PHP程序,類似于Java中的jar機制。
###### 1.2.6 ereg 正則表達式函數 不再默認可用,請使用速度更快的PCRE 正則表達式函數
詳細的請看 http://blog.csdn.net/baiwz/article/details/9077825
##### 1.3 棄用功能
PHP 5.3.0 新增了兩個錯誤等級: E_DEPRECATED 和 E_USER_DEPRECATED. 錯誤等級 E_DEPRECATED 被用來說明一個函數或者功能已經被棄用. E_USER_DEPRECATED 等級目的在于表明用戶代碼中的棄用功能, 類似于 E_USER_ERROR 和 E_USER_WARNING 等級.
下面是被棄用的 INI 指令列表. 使用下面任何指令都將導致 E_DEPRECATED 錯誤.
> define_syslog_variables
> register_globals
> register_long_arrays
> safe_mode
> magic_quotes_gpc
> magic_quotes_runtime
> magic_quotes_sybase
棄用 INI 文件中以 '#' 開頭的注釋.
棄用函數:
~~~
call_user_method() (使用 call_user_func() 替代)
call_user_method_array() (使用 call_user_func_array() 替代)
define_syslog_variables()
dl()
ereg() (使用 preg_match() 替代)
ereg_replace() (使用 preg_replace() 替代)
eregi() (使用 preg_match() 配合 'i' 修正符替代)
eregi_replace() (使用 preg_replace() 配合 'i' 修正符替代)
set_magic_quotes_runtime() 以及它的別名函數 magic_quotes_runtime()
session_register() (使用 $_SESSION 超全部變量替代)
session_unregister() (使用 $_SESSION 超全部變量替代)
session_is_registered() (使用 $_SESSION 超全部變量替代)
set_socket_blocking() (使用 stream_set_blocking() 替代)
split() (使用 preg_split() 替代)
spliti() (使用 preg_split() 配合 'i' 修正符替代)
sql_regcase()
mysql_db_query() (使用 mysql_select_db() 和 mysql_query() 替代)
mysql_escape_string() (使用 mysql_real_escape_string() 替代)
~~~
廢棄以字符串傳遞區域設置名稱. 使用 LC_* 系列常量替代.
mktime() 的 is_dst 參數. 使用新的時區處理函數替代.
棄用的功能:
棄用通過引用分配 new 的返回值.
調用時傳遞引用被棄用.
#### 2. PHP 5.4中的新特性
##### 2.1 PHP 5.4中的新特性
###### 2.1.1 Buid-in web server內置了一個簡單的Web服務器
把當前目錄作為Root Document只需要這條命令即可:
~~~
$ php -S localhost:3300
~~~
也可以指定其它路徑:
~~~
$ php -S localhost:3300 -t /path/to/root
~~~
還可以指定路由:
~~~
$ php -S localhost:3300 router.php
~~~
###### 2.1.2 Traits
Traits提供了一種靈活的代碼重用機制,即不像interface一樣只能定義方法但不能實現,又不能像class一樣只能單繼承。至于在實踐中怎樣使用,還需要深入思考。
魔術常量為__TRAIT__
官網的一個例子:
~~~
trait SayWorld {
public function sayHello() {
parent::sayHello();
echo "World!\n";
echo 'ID:' . $this->id . "\n";
}
}
class Base {
public function sayHello() {
echo 'Hello ';
}
}
class MyHelloWorld extends Base {
private $id;
public function __construct() {
$this->id = 123456;
}
use SayWorld;
}
$o = new MyHelloWorld();
$o->sayHello();
/*will output:
Hello World!
ID:123456
*/
~~~
###### 2.1.3 Short array syntax 數組簡短語法
~~~
$arr = [1,'james', 'james@fwso.cn'];
$array = [
"foo" => "bar",
"bar" => "foo"
];
~~~
###### 2.1.4 Array dereferencing 數組值
~~~
function myfunc() {
return array(1,'james', 'james@fwso.cn');
}
~~~
我認為比數組簡短語法更方便的是dereferencing,以前我們需要這樣:
~~~
$arr = myfunc();
echo $arr[1];
~~~
在PHP5.4中這樣就行了:
~~~
echo myfunc()[1];
~~~
其他:
~~~
$name = explode(",", "Laruence,male")[0];
explode(",", "Laruence,male")[3] = "phper";
~~~
本例要注意一個要點 http://www.laruence.com/2011/12/19/2409.html
###### 2.1.5 Upload progress 文件上傳
Session提供了上傳進度支持,通過`$_SESSION["upload_progress_name"]`就可以獲得當前文件上傳的進度信息,結合Ajax就能很容易實現上傳進度條了。
詳細的看
http://www.laruence.com/2011/10/10/2217.html
###### 2.1.6 JsonSerializable Interface [JSON 序列化對象]
實現了JsonSerializable接口的類的實例在json_encode序列化的之前會調用jsonSerialize方法,而不是直接序列化對象的屬性。
參考:http://www.laruence.com/2011/10/10/2204.html
###### 2.1.7 Use mysqlnd by default
現在mysql, mysqli, pdo_mysql默認使用mysqlnd本地庫,在PHP5.4以前需要:
~~~
$./configure --with-mysqli=mysqlnd
~~~
現在:
~~~
$./configure --with-mysqli
~~~
以上來自:http://www.hdj.me/php54
###### 2.1.8 實例化類
~~~
class test{
function show(){
return 'test';
}
}
echo (new test())->show();
~~~
###### 2.1.9 支持 Class::{expr}() 語法
~~~
foreach ([new Human("Gonzalo"), new Human("Peter")] as $human) {
echo $human->{'hello'}();
}
~~~
###### 2.1.10 Callable typehint
~~~
function foo(callable $callback) {
}
~~~
則:
~~~
foo("false"); //錯誤,因為false不是callable類型
foo("printf"); //正確
foo(function(){}); //正確
class A {
static function show() {
}
}
foo(array("A", "show")); //正確
~~~
###### 2.1.11 函數類型提示的增強
由于php是弱類型的語言,因此在php 5.0后,引入了函數類型提示的功能,其含義為對于傳入函數中的參數都進行類型檢查,舉個例子,有如下的類:
~~~
//其中函數foo中的參數規定了傳入的參數必須為bar類的實例,否則系統會判斷出錯。
class bar {
function foo(bar $foo) {}
}
~~~
同樣對于數組來說,也可以進行判斷,比如:
~~~
function foo(array $foo) {
}
}
foo(array(1, 2, 3)); // 正確,因為傳入的是數組
foo(123); // 不正確,傳入的不是數組
~~~
###### 2.1.12 新增加了`$_SERVER["REQUEST_TIME_FLOAT"]`
這個是用來統計服務請求時間的,并用ms來表示
~~~
echo "腳本執行時間 ", round(microtime(true) - $_SERVER["REQUEST_TIME_FLOAT"], 2), "s";
~~~
###### 2.1.13 讓Json更懂中文(JSON_UNESCAPED_UNICODE)
~~~
echo json_encode("中文", JSON_UNESCAPED_UNICODE);
//"中文"
~~~
###### 2.1.14 二進制直接量(binary number format)
~~~
$bin = 0b1101;
echo $bin;
//13
~~~
##### 2.2 PHP 5.4.0 性能大幅提升, 修復超過100個bug.
廢除了register_globals, magic_quotes以及安全模式。
另外值得一提的是多字節支持已經默認啟用了,
default_charset從ISO-8859-1已經變為UTF-8.
默認發送“Content-Type: text/html; charset=utf-8”,
你再也不需要在HTML里寫meta tag,也無需為UTF-8兼容而傳送額外的header了。
刪除的特性
最后,我們集中整理了幾年來標記為已棄用的多個特性。這些特性包括 `allow_call_time_pass_reference、define_syslog_variables、highlight.bg、register_globals、register_long_arrays、magic_quotes、safe_mode、zend.ze1_compatibility_mode、session.bug_compat42、session.bug_compat_warn `以及 `y2k_compliance`。
除了這些特性之外,magic_quotes 可能是最大的危險。在早期版本中,未考慮因 magic_quotes 出錯導致的后果,簡單編寫且未采取任何舉措使自身免受 SQL 注入攻擊的應用程序都通過 magic_quotes 來保護。如果在升級到 PHP 5.4 時未驗證已采取正確的 SQLi 保護措施,則可能導致安全漏洞。
其他改動和特性
有一種新的“可調用的”類型提示,用于某方法采用回調作為參數的情況。
htmlspecialchars() 和 htmlentities() 現在可更好地支持亞洲字符,如果未在 php.ini 文件中顯式設置 PHP default_charset,這兩個函數默認使用 UTF-8 而不是 ISO-8859-1。
`<?=(精簡回顯語法)`現在始終可用,無論 short_tags ini 設置的值為何。這應該使模板化系統創建者感到滿意。
會話 ID 現在默認通過 /dev/urandom(或等效文件)中的熵生成,而不是與早期版本一樣成為必須顯式啟用的一個選項。
mysqlnd 這一捆綁的 MySQL 原生驅動程序庫現在默認用于與 MySQL 通信的各種擴展,除非在編譯時通過 ./configure 被顯式覆蓋。
可能還有 100 個小的改動和特性。從 PHP 5.3 升級到 5.4 應該極為順暢,但請閱讀遷移指南加以確保。如果您從早期版本升級,執行的操作可能稍多一些。請查看以前的遷移指南再開始升級。
##### 2.3 PHP5.4棄用功能
備受指責的 Register Globals 已從 PHP 中完全刪除。十年來,該特性一直以其頻繁發生的安全漏洞而著稱。2002年該特性被設置為默認關閉。2009年發布的 PHP5.3 將該特性標記為“棄用”,想必從那時起,大部分開發人員已經不再使用它。
從 PHP 中移除的另一個不討喜的特性是 Magic Quotes。Magic Quotes 本意是對字符串進行自動轉義(escape)以試圖避免 SQL 注入攻擊。但是由于字符串的轉義使用方法常與特定背景相關,因此,比起試圖解決的問題,它反而造成了更多的問題。該特性同 Register Globals 一樣,也在 2009 年被標記為“棄用”。
PHP 中的 break 和 continue 語句之后可以跟上一個參數用來指明跳出的循環層數。如果不指定參數,它會像 VB、C#或 Java 一樣跳出最內層的循環。在 PHP 5.4 之前,開發人員可以向 break 語句傳遞一個變量,而現在只能傳遞常量。
PHP 允許參數按引用傳遞。在早期版本中,你可以通過為調用點添加修飾來指明變量按引用傳遞。在 PHP 5.4 中,該選項已被移除。相反,現代 PHP 編程只需要在函數聲明時指定按引用傳遞即可。與 C# 不同,你不需要同時在聲明和調用點指定按引用傳遞。
#### 3. PHP 5.5中的新特性
##### 3.1.PHP 5.5中的新特性
新特性及提案列表 都相當大,而且不是按重要性排序。所以,如果你不想通讀一遍的話,這里有四個特點我個人是最興奮的:
1. 一個簡單的密碼散列API
2. 標量類型提示
3. Getter和Setter
4. 生成器
現在,讓我們來看看PHP5.5 可能會新增的功能:
###### 3.1.1 放棄對Windows XP和2003 的支持
###### 3.1.2 棄用e修飾符
e修飾符是指示preg_replace函數用來評估替換字符串作為PHP代碼,而不只是僅僅做一個簡單的字符串替換。不出所料,這種行為會源源不斷的出現安全問題。這就是為什么在PHP5.5 中使用這個修飾符將拋出一個棄用警告。作為替代,你應該使用preg_replace_callback函數。你可以從RFC找到更多關于這個變化相應的信息。
###### 3.1.3 新增函數和類
boolval()
PHP已經實現了strval、intval和floatval的函數。為了達到一致性將添加boolval函數。它完全可以作為一個布爾值計算,也可以作為一個回調函數。
hash_pbkdf2()
PBKDF2全稱“Password-Based Key Derivation Function 2”,正如它的名字一樣,是一種從密碼派生出加密密鑰的算法。這就需要加密算法,也可以用于對密碼哈希。更廣泛的說明和用法示例
array_column()
~~~
//從數據庫獲取一列,但返回是數組。
$userNames = [];
foreach ($users as $user) {
$userNames[] = $user['name'];
}
//以前獲取數組某列值,現在如下
$userNames = array_column($users, 'name');
~~~
intl 擴展
將有許多改進 intl的擴展。例如,將會有新的IntlCalendar,IntlGregorianCalendar,IntlTimeZone,IntlBreakIterator,IntlRuleBasedBreakIterator,IntlCodePointBreakIterator類。之前,我竟然不知道有這么多關于intl擴展,如果你想知道更多,我建議你去最新公告里找 Calendar和 BreakIterator。
###### 3.1.4 一個簡單的密碼散列API
~~~
$password = "foo";
// creating the hash
$hash = password_hash($password, PASSWORD_BCRYPT);
// verifying a password
if (password_verify($password, $hash)) {
// password correct!
} else {
// password wrong!
}
~~~
###### 3.1.5 新的語言特性和增強功能。
常量引用
“常量引用”意味著數組可以直接操作字符串和數組字面值。舉兩個例子:
~~~
function randomHexString($length) {
$str = '';
for ($i = 0; $i < $length; ++$i) {
$str .= "0123456789abcdef"[mt_rand(0, 15)]; // direct dereference of string
}
}
function randomBool() {
return [false, true][mt_rand(0, 1)]; // direct dereference of array
}
~~~
我不認為在實踐中會使用此功能,但它使語言更加一致。請參閱 RFC。
###### 3.1.6 調用empty()函數(和其他表達式)一起工作
目前,empty()語言構造只能用在變量,而不能在其他表達式。
在特定的代碼像empty($this->getFriends())將會拋出一個錯誤。作為PHP5.5 這將成為有效的代碼
###### 3.1.7 獲取完整類別名稱
PHP5.3 中引入命名空間的別名類和命名空間短版本的功能。雖然這并不適用于字符串類名稱
~~~
use Some\Deeply\Nested\Namespace\FooBar;
// does not work, because this will try to use the global `FooBar` class
$reflection = new ReflectionClass('FooBar');
echo FooBar::class;
~~~
為了解決這個問題采用新的FooBar::class語法,它返回類的完整類別名稱
###### 3.1.8.參數跳躍
如果你有一個函數接受多個可選的參數,目前沒有辦法只改變最后一個參數,而讓其他所有參數為默認值。
RFC上的例子,如果你有一個函數如下:
~~~
function create_query($where, $order_by, $join_type='', $execute = false, $report_errors = true) { ... }
~~~
那么有沒有辦法設置$report_errors=false,而其他兩個為默認值。
為了解決這個跳躍參數的問題而提出:
~~~
create_query("deleted=0", "name", default, default, false);
~~~
我個人不是特別喜歡這個提議。在我的眼睛里,代碼需要這個功能,只是設計不當。函數不應該有12個可選參數。
###### 3.1.9.標量類型提示
標量類型提示原本計劃進入5.4,但由于缺乏共識而沒有做。獲取更多關于為什么標量類型提示沒有做進PHP的信息,請參閱: 標量類型提示比你認為的更難。
對于PHP5.5 而言,針對標量類型提示討論又一次出現,我認為這是一個相當不錯的 提議。
它需要通過輸入值來指定類型。例如:123,123.0,“123”都是一個有效的int參數輸入,但“hello world”就不是。這與內部函數的行為一致。
~~~
function foo(int $i) { ... }
foo(1); // $i = 1
foo(1.0); // $i = 1
foo("1"); // $i = 1
foo("1abc"); // not yet clear, maybe $i = 1 with notice
foo(1.5); // not yet clear, maybe $i = 1 with notice
foo([]); // error
foo("abc"); // error
~~~
###### 3.1.10 Getter 和 Setter
如果你從不喜歡寫這些getXYZ()和setXYZ($value)方法,那么這應該是你最受歡迎的改變。提議添加一個新的語法來定義一個屬性的設置/讀取:
~~~
<?php
class TimePeriod {
public $seconds;
public $hours {
get { return $this->seconds / 3600; }
set { $this->seconds = $value * 3600; }
}
}
$timePeriod = new TimePeriod;
$timePeriod->hours = 10;
var_dump($timePeriod->seconds); // int(36000)
var_dump($timePeriod->hours); // int(10)
~~~
當然還有更多的功能,比如只讀屬性。如果你想要知道更多,請參閱 RFC。
###### 3.1.11 生成器 yield
目前,自定義迭代器很少使用,因為它們的實現,需要大量的樣板代碼。生成器解決這個問題,并提供了一種簡單的樣板代碼來創建迭代器。
例如,你可以定義一個范圍函數作為迭代器:
~~~
<?php
function *xrange($start, $end, $step = 1) {
for ($i = $start; $i < $end; $i += $step) {
yield $i;
}
}
foreach (xrange(10, 20) as $i) {
// ...
}
~~~
上述xrange函數具有與內建函數相同的行為,但有一點區別:不是返回一個數組的所有值,而是返回一個迭代器動態生成的值。
###### 3.1.12 列表解析和生成器表達式
列表解析提供一個簡單的方法對數組進行小規模操作:
~~~
$firstNames = [foreach ($users as $user) yield $user->firstName];
~~~
上述列表解析相等于下面的代碼:
~~~
$firstNames = [];
foreach ($users as $user) {
$firstNames[] = $user->firstName;
}
~~~
也可以這樣過濾數組:
~~~
$underageUsers = [foreach ($users as $user) if ($user->age < 18) yield $user];
~~~
生成器表達式也很類似,但是返回一個迭代器(用于動態生成值)而不是一個數組。
以上來自:http://www.oschina.net/question/157182_61259
###### 3.1.13.finally關鍵字
這個和java中的finally一樣,經典的try ... catch ... finally 三段式異常處理。
###### 3.1.14 foreach 支持list()
對于“數組的數組”進行迭代,之前需要使用兩個foreach,現在只需要使用foreach + list了,但是這個數組的數組中的每個數組的個數需要一樣。看文檔的例子一看就明白了。
~~~
$array = [
[1, 2],
[3, 4],
];
foreach ($array as list($a, $b)) {
echo "A: $a; B: $b\n";
}
~~~
###### 3.1.15 增加了opcache擴展
使用opcache會提高php的性能,你可以和其他擴展一樣靜態編譯(--enable-opcache)或者動態擴展(zend_extension)加入這個優化項。
###### 3.1.16 非變量array和string也能支持下標獲取了
~~~
echo array(1, 2, 3)[0];
echo [1, 2, 3][0];
echo "foobar"[2];
~~~
#### 4. PHP5.6
原文連接http://cn2.php.net/manual/zh/migration56.new-features.php
###### 4.1.1 常量增強
允許常量計算,允許使用包含數字、字符串字面值和常量的標量表達式
~~~
const A = 2;
const B = A + 1;
class C
{
const STR = "hello";
const STR2 = self::STR + ", world";
}
~~~
允許常量作為函數參數默認
~~~
function test($arg = C::STR2)
~~~
##### 4.2 可變函數參數
代替 func_get_args()
~~~
function add(...$args)
{
$result = 0;
foreach($args as $arg)
$result += $arg;
return $result;
}
~~~
4.3 參數解包功能
在調用函數的時候,通過 ... 操作符可以把數組或者可遍歷對象解包到參數列表,這和Ruby等語言中的擴張(splat)操作符類似
~~~
function add($a, $b, $c) {
return $a + $b + $c;
}
$arr = [2, 3];
add(1, ...$arr);
~~~
4.4 命名空間 use 操作符開始支持函數和常量的導入
~~~
namespace Name\Space {
const FOO = 42;
function f() { echo __FUNCTION__."\n"; }
}
namespace {
use const Name\Space\FOO;
use function Name\Space\f;
echo FOO."\n";
f();
}
~~~
輸出
> 42
Name\Space\f
4.5 使用**操作符計算乘方
4.6 phpdbg
PHP自帶了一個交互式調試器phpdbg,它是一個SAPI模塊,更多信息參考 phpdbg文檔 。
4.7 php://input 可以被復用
php://input 開始支持多次打開和讀取,這給處理POST數據的模塊的內存占用帶來了極大的改善。
4.8 大文件上傳支持
可以上傳超過2G的大文件。
4.9 GMP支持操作符重載
GMP 對象支持操作符重載和轉換為標量,改善了代碼的可讀性,如:
~~~
<?php
$a = gmp_init(42);
$b = gmp_init(17);
// Pre-5.6 code:
var_dump(gmp_add($a, $b));
var_dump(gmp_add($a, 17));
var_dump(gmp_add(42, $b));
// New code:
var_dump($a + $b);
var_dump($a + 17);
var_dump(42 + $b);
~~~
4.10 新增gost-crypto哈希算法
采用CryptoPro S-box tables實現了 gost-crypto 哈希算法,詳情參考 RFC 4357, section 11.2 。
4.11 SSL/TLS改進
OpenSSL擴展新增證書指紋的提取和驗證功能, openssl_x509_fingerprint()用于提取X.509證書的指紋,SSL stream context 選項: capture_peer_cert 用于獲取對方X.509證書; peer_fingerprint 用于斷言對方證書和給定的指紋匹配。
另外,可以通過SSL流上下文選項 crypto_method 指定加密方法,如SSLv3或TLS,目前支持的選項值包括
> STREAM_CRYPTO_METHOD_SSLv2_CLIENT, STREAM_CRYPTO_METHOD_SSLv3_CLIENT, STREAM_CRYPTO_METHOD_SSLv23_CLIENT (默認), or STREAM_CRYPTO_METHOD_TLS_CLIENT。
- 數組
- 深拷貝
- 數組操作
- 交/并/合
- 差值
- 搜索
- 排序
- 貨幣
- 字符串
- 補全
- heredoc
- session
- 注銷
- 限時自動注銷
- 日期時間
- 日期時間
- 某月首尾
- 格式判斷
- 年齡計算
- 時間函數
- strtotime
- 版本升級
- $HTTP_RAW_POST_DATA
- 正則函數等
- 版本比較
- php5.3 PHP5.4 PHP5.5 php5.6 新特性
- PHP注釋
- URL地址
- 頁面超時
- 類方法
- 靜態方法
- 子類靜態方法
- 普通方法和靜態方法
- call_user_func 和 call_user_func_array
- 函數
- 動態函數
- 數組循環
- Math函數
- 取整
- 除數余數
- 運行模式
- CLI 模式
- 常用CLI命令
- 檢測環境支持php_cli模式?
- 調試
- 調試工具
- FirePHP
- ChromePHP
- 內置服務器
- 500 錯誤處理
- 命令行
- 遠程操作
- HTTP
- HTTP headers
- 用例
- 保留字
- 教程
- PHP實戰教程-0基礎快速入門
- 接口與抽象類
- 抽象類與接口的區別
- 魔術方法
- 私有屬性方法
- 構造/析構方法
- PHP Error 和 Logging 函數
- 類
- const