在過去如果我們調(diào)用一個用戶定義的函數(shù)時,提供的參數(shù)不足,那么將會產(chǎn)生一個警告(warning)。 現(xiàn)在,這個警告被提升為一個錯誤異常(Error exception)。這個變更僅對用戶定義的函數(shù)生效, 并不包含內(nèi)置函數(shù)。例如:
<?php
function test($param){}
test();
以上例程的輸出類似于:
Fatal error: Uncaught ArgumentCountError: Too few arguments to function test(), 0 passed in %s on line %d and exactly 1 expected in %s:%d
Dynamic calls for certain functions have been forbidden (in the form of
$func()
or array_map('extract', ...)
,
etc). These functions either inspect or modify another scope, and present
with them ambiguous and unreliable behavior. The functions are as follows:
<?php
(function () {
$func = 'func_num_args';
$func();
})();
以上例程會輸出:
Warning: Cannot call func_num_args() dynamically in %s on line %d
The following names cannot be used to name classes, interfaces, or traits:
Integer operations and conversions on numerical strings now respect
scientific notation. This also includes the (int)
cast
operation, and the following functions: intval() (where
the base is 10), settype(), decbin(),
decoct(), and dechex().
mt_rand() will now default to using the fixed version of
the Mersenne Twister algorithm. If deterministic output from
mt_srand() was relied upon, then the
MT_RAND_PHP
with the ability to preserve the old
(incorrect) implementation via an additional optional second parameter to
mt_srand().
rand() and srand() have now been made aliases to mt_rand() and mt_srand(), respectively. This means that the output for the following functions have changed: rand(), shuffle(), str_shuffle(), and array_rand().
The ASCII delete control character (0x7F
) can no longer
be used in identifiers that are not quoted.
error_log
changes with syslog
value
If the error_log
ini setting is set to
syslog
, the PHP error levels are mapped to the syslog
error levels. This brings finer differentiation in the error logs in
contrary to the previous approach where all the errors are logged with the
notice level only.
對于在執(zhí)行構(gòu)造方法時拋出異常的對象,現(xiàn)在析構(gòu)方法絕不會被調(diào)用。在先前的版本中,這個行為取決于對象是否在構(gòu)造方法以外的地方唄引用(例如一個錯誤堆?;厮荩?
call_user_func() 現(xiàn)在在調(diào)用一個以引用作為參數(shù)的函數(shù)時將始終產(chǎn)生一個警告。先前這取決于這個調(diào)用行為是否完全符合條件。
此外, call_user_func() 和 call_user_func_array() 在這種情況下將不再中斷函數(shù)調(diào)用。現(xiàn)在會出現(xiàn)一個包含"expected reference"的警告信息,但函數(shù)調(diào)用將正常進行。
對字符串使用一個空索引操作符(例如$str[] = $x
)將會拋出一個致命錯誤,
而不是靜默地將其轉(zhuǎn)為一個數(shù)組。
下列ini配置項已經(jīng)被移除:
session.entropy_file
session.entropy_length
session.hash_function
session.hash_bits_per_character
The order of the elements in an array has changed when those elements have been automatically created by referencing them in a by reference assignment. For example:
<?php
$array = [];
$array["a"] =& $array["b"];
$array["b"] = 1;
var_dump($array);
?>
以上例程在 PHP 7.0 中的輸出:
array(2) { ["a"]=> &int(1) ["b"]=> &int(1) }
以上例程在 PHP 7.1 中的輸出:
array(2) { ["b"]=> &int(1) ["a"]=> &int(1) }
The internal sorting algorithm has been improved, what may result in different sort order of elements, which compare as equal, than before.
注意:
Don't rely on the order of elements which compare as equal; it might change anytime.
The error message for E_RECOVERABLE errors has been changed from "Catchable fatal error" to "Recoverable fatal error".
The allowed_classes
element of the $options parameter of
unserialize() is now strictly typed, i.e. if anything
other than an array or a bool is given,
unserialize() returns false
and issues an E_WARNING
.
DateTime and DateTimeImmutable
now properly incorporate microseconds when constructed from the current time,
either explicitly or with a relative string (e.g. "first day of next
month"
). This means that naive comparisons of two newly created
instances will now more likely return false
instead of true
:
<?php
new DateTime() == new DateTime();
?>
In the Date extension, invalid serialization data for DateTime or DatePeriod classes, or timezone initialization failure from serialized data, will now throw an Error exception from the __wakeup() or __set_state() methods, instead of resulting in a fatal error.
In the DBA extension, data modification functions (such as dba_insert()) will now throw an Error exception instead of triggering a catchable fatal error if the key does not contain exactly two elements.
In the DOM extension, invalid schema or RelaxNG validation contexts will now throw an Error exception instead of resulting in a fatal error. Similarly, attempting to register a node class that does not extend the appropriate base class, or attempting to read an invalid property or write to a readonly property, will also now throw an Error exception.
In the IMAP extension, email addresses longer than 16385 bytes will throw an Error exception instead of resulting in a fatal error.
In the Intl extension, failing to call the parent constructor in a class extending Collator before invoking the parent methods will now throw an Error instead of resulting in a recoverable fatal error. Also, cloning a Transliterator object will now throw an Error exception on failure to clone the internal transliterator instead of resulting in a fatal error.
In the LDAP extension, providing an unknown modification type to ldap_batch_modify() will now throw an Error exception instead of resulting in a fatal error.
In the mbstring extension, the mb_ereg() and mb_eregi() functions will now throw a ParseError exception if an invalid PHP expression is provided and the 'e' option is used.
In the Mcrypt extension, the mcrypt_encrypt() and mcrypt_decrypt() will now throw an Error exception instead of resulting in a fatal error if mcrypt cannot be initialized.
In the mysqli extension, attempting to read an invalid property or write to a readonly property will now throw an Error exception instead of resulting in a fatal error.
In the Reflection extension, failing to retrieve a reflection object or retrieve an object property will now throw an Error exception instead of resulting in a fatal error.
In the Session extension, custom session handlers that do not return strings for session IDs will now throw an Error exception instead of resulting in a fatal error when a function is called that must generate a session ID.
In the SimpleXML extension, creating an unnamed or duplicate attribute will now throw an Error exception instead of resulting in a fatal error.
In the SPL extension, attempting to clone an SplDirectory object will now throw an Error exception instead of resulting in a fatal error. Similarly, calling ArrayIterator::append() when iterating over an object will also now throw an Error exception.
In the standard extension, the assert() function, when provided with a string argument as its first parameter, will now throw a ParseError exception instead of resulting in a catchable fatal error if the PHP code is invalid. Similarly, calling forward_static_call() outside of a class scope will now throw an Error exception.
In the Tidy extension, creating a tidyNode manually will now throw an Error exception instead of resulting in a fatal error.
In the WDDX extension, a circular reference when serializing will now throw an Error exception instead of resulting in a fatal error.
In the XML-RPC extension, a circular reference when serializing will now throw an instance of Error exception instead of resulting in a fatal error.
In the Zip extension, the ZipArchive::addGlob() method will now throw an Error exception instead of resulting in a fatal error if glob support is not available.
Variables bound to a closure via
the use
construct cannot use the same name as any
superglobals, $this, or any parameter. For
example, all of these function definition will result in a fatal error:
<?php
$f = function () use ($_SERVER) {};
$f = function () use ($this) {};
$f = function ($param) use ($param) {};
long2ip() now expects an int instead of a string.
The serialize_precision
ini setting now controls the
serialization precision when encoding doubles.
Decoding an empty key now results in an empty property name, rather than
_empty_
as a property name.
<?php
var_dump(json_decode(json_encode(['' => 1])));
以上例程的輸出類似于:
object(stdClass)#1 (1) { [""]=> int(1) }
When supplying the JSON_UNESCAPED_UNICODE
flag to
json_encode(), the sequences U+2028 and U+2029 are now
escaped.
The third parameter to the mb_ereg() and
mb_eregi() functions (regs
) will now be
set to an empty array if nothing was matched. Formerly, the parameter would
not have been modified.
The sslv2 stream has now been dropped in OpenSSL.
Return statements without argument in functions which declare a return type
now trigger E_COMPILE_ERROR
(unless the return type is
declared as void), even if the return statement would never be
reached.