您好,登錄后才能下訂單哦!
PHP7版本優化了哪些內容?很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。
現在官方發布最新版本是php7.2而php6版本被跳過直接迎來了php7。
php7的一些特性
打破一切
PHP7要打破一切。 PHP開發人員應該接受打破版本之間向下兼容的定律。只要不允許大量的向后兼容,PHP7將是一個高度尊重的語言。
1、創建一個具體的核心語言 刪除所有庫方法,并保持在對象集中的核心方法。 您應該能夠編寫無需任何外部庫或擴展PHP7和對基本輸入/輸出,字符串處理和數學一個很好的完整的語言。庫以外的任何應該通過批準擴展。
2、 一切都當作一個對象 以從Ruby,Smalltalk和(主要)的Java對象,并把它一切當作對象。 整數是對象,字符串是對象,他們每個人都可以操作的方法, 我不相信PHP需要的Ruby和Smalltalk在對象之間傳遞彼此訊息的觀念,而調用對象的方法才是最好的。
3、一致的命名方法和類 由于PHP的最大的抱怨之一是不斷要檢查,(needle,haystack) 或(haystack, needle),或some_function(),或function_some(),或someFunction(),一個一致的格式需要制定。
4、讓事情嚴格嘗試傳遞到一個方法浮動字符串? 這是一個警告。
5、 一切是Unicode 在PHP6中的所有字符串都是Unicode,這很好,我主張PHP7也應該保持。
6、中央啟動點 創建一個主類或初始化,所有代碼執行源于此。
7、清理C代碼我不是一個C的專家,但如果你比較了解Ruby的C代碼到PHP的C代碼,可以很容易地了解了PHP與Ruby的內部。 我非常熟悉PHP,所以我自己的寫擴展更容易。
8、擺脫eval() eval()是邪惡的。 如果你正在使用它,那么這是一個錯的主意:這將打破PHPUnit,拋棄它從現在開始。
9、支持操作符重載 因為一切都是對象,開發者只需掌握操作對象的方法即可。
10、允許的方法簽名
可以使用字符串(string), 整數 (int), 浮點數 (float), 以及布爾值 (bool),來聲明函數的參數類型與函數返回值。
代碼:
declare(strict_types=1); function add(int $a,int $b):int{ return $a+$b; } echo add(1, 2).'<br>'; echo add(1.5, 2.6);
返回結果:
在php-5.6.27版本及以前版本的返回結果為:
在php-7.0.12版本及以后版本的返回結果為:
php5是無法執行上面代碼的,php7執行的時候會先輸出一個3和一個報錯( Argument 1 passed to add() must be of the type integer, float given);
標量類型聲明 有兩種模式: 強制 (默認) 和 嚴格模式。
declare(strict_types=1),必須放在文件的第一行執行代碼,當前文件有效!
在 PHP 7 中,很多致命錯誤以及可恢復的致命錯誤,都被轉換為異常來處理了。 這些異常繼承自 Error 類,此類實現了 Throwable 接口 (所有異常都實現了這個基礎接口)。
PHP7進一步方便開發者處理, 讓開發者對程序的掌控能力更強. 因為在默認情況下, Error會直接導致程序中斷, 而PHP7則提供捕獲并且處理的能力, 讓程序繼續執行下去, 為程序員提供更靈活的選擇。
代碼:
$a=1;$b=1; $a1=2;$b1=1; $a2=1;$b2=2; $c=$a<=>$b; $c1=$a1<=>$b1; $c2=$a2<=>$b2; echo "當\$a=\$b的時候,\$的返回結果為:".$c.'<br>'; echo "當\$a1>\$b1的時候,\$的返回結果為:".$c1.'<br>'; echo "當\$a2<\$b2的時候,\$的返回結果為:".$c2.'<br>';
結果:
在php-5.6.27版本及以前版本的返回結果為:
在php-7.0.12版本及以后版本的返回結果為:
語法:$c = $a <=> $b
如果$a > $b, $c 的值為1
如果$a == $b, $c 的值為0
如果$a < $b, $c 的值為-1
如果變量存在且值不為NULL, 它就會返回自身的值,否則返回它的第二個操作數。
代碼:
$data['sex']='女'; $data['sex2']='男'; //原寫法 $sex1 = isset($data['sex']) ? $data['sex'] : '男'; $sex2 = isset($data['sex2']) ? $data['sex2'] : '男'; //現在 $sex3 = $data['sex'] ?? '男'; $sex4 = $data['sex2'] ?? '女'; //$_GET['sex']和$_GET['sex2']均未傳值。 $sex5 = $_GET['sex'] ?? '男'; $sex6 = $_GET['sex2'] ?? '女'; echo '當獲取到的參數為女時原寫法返回結果為:'.$sex1."<br>"; echo '當獲取到的參數為女時現寫法返回結果為:'.$sex3."<br>"; echo '當獲取到的參數為男時原寫法返回結果為:'.$sex2."<br>"; echo '當獲取到的參數為男時現寫法返回結果為:'.$sex4."<br>"; echo '當獲取到的參數為空時原寫法返回結果為:'.$sex5."<br>"; echo '當獲取到的參數為空時現寫法返回結果為:'.$sex6."<br>";
結果:
在php-5.6.27版本及以前版本的返回結果為:
在php-7.0.12版本及以后版本的返回結果為:
操作符“??”在php7版本就相當于三目運算符的升級版。
代碼:
define('ARR',['a','b']); echo ARR[1];// a
結果:
在php-5.6.27版本及以前版本的返回結果為:
AST在PHP編譯過程作為一個中間件的角色, 替換原來直接從解釋器吐出opcode的方式, 讓解釋器(parser)和編譯器(compliler)解耦, 可以減少一些Hack代碼, 同時, 讓實現更容易理解和可維護.
PHP5 : PHP代碼 -> Parser語法解析 -> OPCODE -> 執行
PHP7 : PHP代碼 -> Parser語法解析 -> AST -> OPCODE -> 執行
代碼:
$anonymous_func = function(){return 'function';}; echo $anonymous_func(); // 輸出function
結果:
在php-5.2.17版本及以前版本的返回結果為:
在php-5.3.29版本及以后版本的返回結果為:
代碼:
$anonymous_func = function(){return 'function';}; echo $anonymous_func(); // 輸出function
結果:
在php-5.6.27版本及以前版本的返回結果為:
在php-7.0.12版本及以后版本的返回結果為:
防止非法數據進行代碼注入,提供了更安全的反序列化數據。
// PHP7以前語法的寫法 use FooLibrary\Bar\Baz\ClassA; use FooLibrary\Bar\Baz\ClassB; // PHP7新語法寫法 use FooLibrary\Bar\Baz\{ ClassA, ClassB};
Ereg 正則表達式
mssql
mysql
sybase_ct
不能使用同名的構造函數
實例方法不能用靜態方法的方式調用
方法調用
call_user_method()
call_user_method_array()
應該采用call_user_func() 和 call_user_func_array()
加密相關函數
mcrypt_generic_end()
mcrypt_ecb()
mcrypt_cbc()
mcrypt_cfb()
mcrypt_ofb()
注意: PHP7.1 以后mcrypt_*序列函數都將被移除。推薦使用:openssl 序列函數
雜項
set_magic_quotes_runtime
set_socket_blocking
Split
imagepsbbox()
imagepsencodefont()
imagepsextendfont()
imagepsfreefont()
imagepsloadfont()
imagepsslantfont()
imagepstext()
$HTTP_RAW_POST_DATA 變量被移除, 使用php://input來代
ini文件里面不再支持#開頭的注釋, 使用”;”
移除了ASP格式的支持和腳本語法的支持: <% 和 < script language=php >
含有十六進制字符的字符串不再視為數字, 也不再區別對待.
var_dump("0x123" == "291"); // false var_dump(is_numeric("0x123")); // false var_dump("0xe" + "0x1"); // 0 var_dump(substr("f00", "0x1")) // foo
Int64支持, 統一不同平臺下的整型長度, 字符串和文件上傳都支持大于2GB. 64位PHP7字符串長度可以超過2^31次方字節.
// 無效的八進制數字(包含大于7的數字)會報編譯錯誤 $i = 0681; // 老版本php會把無效數字忽略。 // 位移負的位置會產生異常 var_dump(1 >> -1); // 左位移超出位數則返回0 var_dump(1 << 64);// 0 // 右位移超出會返回0或者-1 var_dump(100 >> 32);// 0 var_dump(-100 >> 32);// -1
不支持重復參數命名
function func(a,b, c,c) {} ;會報錯
func_get_arg()和func_get_args()這兩個方法返回參數當前的值, 而不是傳入時的值, 當前的值有可能會被修改
所以需要注意,在函數第一行最好就給記錄下來,否則后續有修改的話,再讀取就不是傳進來的初始值了。
function foo($x) { $x++; echo func_get_arg(0); } foo(1); //返回2
foreach()循環對數組內部指針不再起作用
$arr = [1,2,3]; foreach ($arr as &$val) { echo current($arr);// php7 全返回0 }
按照值進行循環的時候, foreach是對該數組的拷貝操作
$arr = [1,2,3]; foreach ($arr as $val) { unset($arr[1]); } var_dump($arr);
最新的php7依舊會打印出[1,2,3]。(ps:7.0.0不行)
老的會打印出[1,3]
按照引用進行循環的時候, 對數組的修改會影響循環
$arr = [1]; foreach ($arr as $val) { var_dump($val); $arr[1]=2; }
最新的php7依舊會追加新增元素的循環。(ps:7.0.0不行)
不再按照相反的順序賦值
//$arr將會是[1,2,3]而不是之前的[3,2,1] list($arr[], $arr[], $arr[]) = [1,2,3];
不再支持字符串拆分功能
// $x = null 并且 $y = null $str = 'xy'; list($x, $y) = $str;
空的list()賦值不再允許
list() = [123];
list()現在也適用于數組對象
list($a, $b) = (object)new ArrayObject([0, 1]);
對變量、屬性和方法的間接調用現在將嚴格遵循從左到右的順序來解析,而不是之前的混雜著幾個特殊案例的情況。 下面這張表說明了這個解析順序的變化。
引用賦值時自動創建的數組元素或者對象屬性順序和以前不同了
$arr = []; $arr['a'] = &$arr['b']; $arr['b'] = 1; // php7: ['a' => 1, 'b' => 1] // php5: ['b' => 1, 'a' => 1]
1.debug_zval_dump() 現在打印 “int” 替代 “long”, 打印 “float” 替代 “double”
2.dirname() 增加了可選的第二個參數, depth, 獲取當前目錄向上 depth 級父目錄的名稱。
3.getrusage() 現在支持 Windows.mktime() and gmmktime() 函數不再接受 is_dst 參數。
4.preg_replace() 函數不再支持 “\e” (PREG_REPLACE_EVAL). 應當使用 preg_replace_callback() 替代。
5.setlocale() 函數不再接受 category 傳入字符串。 應當使用 LC_* 常量。
6.exec(), system() and passthru() 函數對 NULL 增加了保護.
7.shmop_open() 現在返回一個資源而非一個int, 這個資源可以傳給shmop_size(), shmop_write(), shmop_read(), shmop_close() 和 shmop_delete().
8.為了避免內存泄露,xml_set_object() 現在在執行結束時需要手動清除 $parse。
9.curl_setopt 設置項CURLOPT_SAFE_UPLOAD變更
TRUE 禁用 @ 前綴在 CURLOPT_POSTFIELDS 中發送文件。 意味著 @ 可以在字段中安全得使用了。 可使用 CURLFile作為上傳的代替。
PHP 5.5.0 中添加,默認值 FALSE。 PHP 5.6.0 改默認值為 TRUE。. PHP 7 刪除了此選項, 必須使用 CURLFile interface 來上傳文件。
zend_extension=opcache.so
opcache.enable=1
opcache.enable_cli=1
只有GCC 4.8以上PHP才會開啟Global Register for opline and execute_data支持, 這個會帶來5%左右的性能提升(Wordpres的QPS角度衡量)
第一次編譯成功后,用項目代碼去訓練PHP,會產生一些profile信息,最后根據這些信息第二次gcc編譯PHP就可以得到量身定做的PHP7
需要選擇在你要優化的場景中: 訪問量最大的, 耗時最多的, 資源消耗最重的一個頁面.
如何更好的寫代碼來迎接PHP7?
逐步剔除php7不支持的代碼
檢測工具:https://github.com/sstalle/php7cc
看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。