欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

php7 參數(shù)、整形及字符串處理機制修改實例分析

 更新時間:2020年05月25日 10:30:14   作者:人生如初見_張默  
這篇文章主要介紹了php7 參數(shù)、整形及字符串處理機制修改,結合實例形式分析了php7 參數(shù)、整形及字符串處理機制較舊版本的區(qū)別及相關操作注意事項,需要的朋友可以參考下

本文實例講述了php7 參數(shù)、整形及字符串處理機制修改。分享給大家供大家參考,具體如下:

參數(shù)處理機制修改

一、重復參數(shù)命名不再支持。

重復的參數(shù)命名不再支持。比如下面的代碼執(zhí)行的時候會報錯:

public function foo($a, $b, $unused, $unused) {
// ... 
}

編者按:應該沒有人這樣用吧。

二、func_get_arg和func_get_args()調整

func_get_arg()和func_get_args()這兩個方法返回參數(shù)當前的值,而不是傳入時的值。當前的值有可能會被修改  

function foo($x) {
   $x++;
   var_dump(func_get_arg(0));
}
foo(1);

上面的代碼會打印2, 而不是1。如果想打印原始的值,調用的順序調整下即可。

三、同樣在打印異?;厮菪畔⒌臅r候也是顯示修改后的值。

function foo($x) {  
 $x = 42;
 throw new Exception; 
} 
foo("string"); 

PHP7的運行結果:

Stack trace:
#0 file.php(4): foo(42)
#1 {main} 

PHP5的運行結果:

Stack trace:
#0 file.php(4): foo('string')
#1 {main}

這個調整不會影響代碼的行為,不過在調試的時候需要注意這個變化。

其他和參數(shù)有關的函數(shù)都是同樣的調整,比如debug_backtrace() .

整型處理機制修改

一、無效八進制數(shù)字會報編譯錯誤

無效的八進制數(shù)字(包含大于7的數(shù)字)會報編譯錯誤,比如下面的代碼會報錯:     

$i = 0781; // 8 is not a valid octal digit!
[點擊并拖拽以移動]

老版本的PHP會把無效的數(shù)字忽略。

二、位移負的位置會產生異常

var_dump(1 >> -1); // ArithmeticError: Bit shift by negative number

三、左位移如果超出位數(shù)返回0

var_dump(1 << 64); // int(0)

老版本的PHP運行結果和cpu架構有關系。比如x86會返回1。

四、右位移超出會返回0或者-1.

var_dump(1 >> 64); // int(0)
var_dump(-1 >> 64); // int(-1)

字符串處理機制修改

一、含有十六進制字符的字符串不再視為數(shù)字

含有十六進制字符的字符串不再視為數(shù)字,也不再區(qū)別對待。比如下面的代碼:

var_dump("0x123" == "291");   // bool(false)   (previously true) 
var_dump(is_numeric("0x123")); // bool(false)   (previously true) 
var_dump("0xe" + "0x1");    // int(0)     (previously 16) 
var_dump(substr("foo", "0x1")); // string(3) "foo" (previously "oo") 
// Notice: A non well formed numeric value encountered

可以使用filter_var函數(shù)來檢查一個字符串是否包含十六進制字符或者是否可以轉成一個整型

$str = "0xffff"; 
$int = filter_var($str, FILTER_VALIDATE_INT, FILTER_FLAG_ALLOW_HEX); 
if (false === $int) {   
throw new Exception("Invalid integer!"); 
}
var_dump($int); // int(65535)

二、\u{后面如果包含非法字符會報錯

雙引號和heredocs語法里面增加了unicode 碼點轉義語法,“\u{”后面必須是utf-8字符。如果是非utf-8字符,會報錯:

$str = "\u{xyz}"; // Fatal error: Invalid UTF-8 codepoint escape sequence

可以通過對第一個\進行轉義來避免這種錯誤。

$str = "\\u{xyz}"; // Works fine

“\u”后面如果沒有{,則沒有影響:

$str = "\u202e"; // Works fine

PHP IntlChar()

PHP 7 通過 intl 擴展來支持國際化 (i18n) 和本地化 (l10n) 。此擴展僅僅是對 ICU 庫的基礎包裝,并提供了和 ICU 庫類似的方法和特性。

PHP 7 通過新的 IntlChar 類暴露出 ICU 中的 Unicode 字符特性。這個類自身定義了許多靜態(tài)方法用于操作多字符集的 unicode 字符。

實例

<?php 
printf('%x', IntlChar::CODEPOINT_MAX); 
echo IntlChar::charName('@'); 
var_dump(IntlChar::ispunct('!')); 
?>

以上程序執(zhí)行輸出結果為:

10ffff
COMMERCIAL AT
bool(true)

更多關于PHP相關內容感興趣的讀者可查看本站專題:《php常用函數(shù)與技巧總結》、《php字符串(string)用法總結》、《PHP數(shù)組(Array)操作技巧大全》、《PHP基本語法入門教程》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總

希望本文所述對大家PHP程序設計有所幫助。

相關文章

最新評論