Bien que la plupart du code PHP 5 existant devrait fonctionner sans aucune modification, vous devez prendre en considération quelques incompatibilités ascendantes :
Le support de Windows XP et 2003 a été supprimé. Les binaires Windows de PHP requièrent maintenant Windows Vista ou supérieur.
Toutes les comparaisons insensibles à la casse pour les noms de fonctions, de classes, et de constantes sont maintenant indépendantes de la locale utilisée, et respectent les règles ASCII. Ceci permet une meilleure prise en charge des langues utilisant l'alphabet latin avec des règles d'assemblage inhabituelles, comme le turc et l'azerbaïdjan.
Ceci peut avoir des impacts sur le code qui utilise l'insensibilité à la casse pour des caractères non-ASCII avec des jeux de caractères multi-octets (incluant l'UTF-8), comme les caractères accentués pour de nombreuses langues européennes. Si vous avez du code basé sur des langues non-anglaises, et non-ASCII, alors vous devriez tester que vous n'êtes pas impacté par ce changement de comportement avant de déployer PHP 5.5 en environnement de production.
Des modifications ont été réalisées sur les fonctions pack() et unpack() pour les rendre plus compatible avec Perl :
L'écriture de code compatible de façon ascendante qui utilise le code format "a" avec la fonction unpack() requiert l'utilisation de la fonction version_compare(), en raison de cette cassure de compatiblité ascendante.
Par exemple :
<?php
// Ancien code :
$data = unpack('a5', $packed);
// Nouveau code :
if (version_compare(PHP_VERSION, '5.5.0-dev', '>=')) {
$data = unpack('Z5', $packed);
} else {
$data = unpack('a5', $packed);
}
?>
Quand la value
passé à json_encode()
déclanche une error d'encodage JSON, FALSE
est désormais retourné au lieu
d'une sortie partielle, sauf si les options
contiennent
JSON_PARTIAL_OUTPUT_ON_ERROR
.
Voir json_last_error() pour la liste complète de raison
qui peuvent provoquer l'échec de l'encodage JSON.
Une des raisons potentielle d'échec et que value
contient des chaîne de caractères contentnant de l'UTF-8 invalide.
self
, parent
et
static
sont maintenant insensible à la casse
Avant PHP 5.5, des cas existaient où les mots clés
self,
parent et
static
étaient traités de façon sensible à la casse. Ceci a maintenant été résolu,
et ces mots clés sont toujours gérés de façon insensible à la casse :
SELF::CONSTANT
est maintenant traité exactement comme
self::CONSTANT
.
Les GUIDs qui permettaient précédemment l'affichage de divers logos PHP ont été supprimés. Ceci inclut la suppression des fonctions qui retournaient ces GUIDs. Voici une liste des fonctions supprimées :
Les auteurs d'extensions devraient noter que la fonction
zend_execute() ne peut plus être surchargée,
et que de nombreux changements ont été effectués sur la structure
execute_data
ainsi que sur les fonctions associées
et sur les opcodes de gestion de méthodes.
La plupart des extensions ne sont normalement pas affectées par ces modifications, mais celles profondément ancrées dans le moteur Zend le seront, et nous recommandons à leurs auteurs de lire les notes relatives à ces modifications.