1.字符串處理機制修改
含有十六進制字符的字符串不再視為數字, 也不再區別對待.
var_dump("0x123" == "291"); // false var_dump(is_numeric("0x123")); // false var_dump("0xe" + "0x1"); // 0 var_dump(substr("f00", "0x1")) // foo
2.整型處理機制修改
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
3.參數處理機制修改
不支持重復參數命名
function func(b, c) {} ;會報錯
func_get_arg()和func_get_args()這兩個方法返回參數當前的值, 而不是傳入時的值, 當前的值有可能會被修改
所以需要注意,在函數第一行最好就給記錄下來,否則后續有修改的話,再讀取就不是傳進來的初始值了。
function foo($x) { $x++; echo func_get_arg(0); } foo(1); //返回2
4.foreach修改
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不行)
5. list修改
不再按照相反的順序賦值
//$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]);
6.變量處理機制修改
對變量、屬性和方法的間接調用現在將嚴格遵循從左到右的順序來解析,而不是之前的混雜著幾個特殊案例的情況。 下面這張表說明了這個解析順序的變化。
引用賦值時自動創建的數組元素或者對象屬性順序和以前不同了
$arr = []; $arr['a'] = &$arr['b'];$arr['b'] = 1; // php7: ['a' => 1, 'b' => 1] // php5: ['b' => 1, 'a' => 1]
7.雜項
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 來上傳文件。
以上就是php7新特性之php7帶來的變更的詳細內容,更多請關注億速云其它相關文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。