mirror of
https://github.com/php/doc-fr.git
synced 2026-03-23 22:52:18 +01:00
167 lines
5.3 KiB
XML
167 lines
5.3 KiB
XML
<?xml version="1.0" encoding="utf-8"?>
|
||
<!-- EN-Revision: e587d0655e426f97b3fcb431453da5030e743b23 Maintainer: yannick Status: ready -->
|
||
<!-- Reviewed: no -->
|
||
<!-- CREDITS: DAnnebicque -->
|
||
<chapter xml:id="language.types" xmlns="http://docbook.org/ns/docbook" annotations="interactive">
|
||
<title>Les types</title>
|
||
|
||
<sect1 xml:id="language.types.intro">
|
||
<title>Introduction</title>
|
||
<para>
|
||
En PHP, chaque expression a l'un des types intégrés suivants en fonction de
|
||
sa valeur:
|
||
<itemizedlist>
|
||
<listitem><simpara><type>null</type></simpara></listitem>
|
||
<listitem><simpara><type>bool</type></simpara></listitem>
|
||
<listitem><simpara><type>int</type></simpara></listitem>
|
||
<listitem><simpara><type>float</type> (nombre à virgule flottante)</simpara></listitem>
|
||
<listitem><simpara><type>string</type></simpara></listitem>
|
||
<listitem><simpara><type>array</type></simpara></listitem>
|
||
<listitem><simpara><type>object</type></simpara></listitem>
|
||
<listitem><simpara><type>callable</type></simpara></listitem>
|
||
<listitem><simpara><type>resource</type></simpara></listitem>
|
||
</itemizedlist>
|
||
</para>
|
||
|
||
<para>
|
||
PHP est un langage typé dynamiquement, ce qui signifie que par défaut, il
|
||
n'est pas nécessaire de spécifier le type d'une variable, car cela sera
|
||
déterminé au moment de l'exécution. Cependant, il est possible de typer
|
||
statiquement certains aspects du langage en utilisant les
|
||
<link linkend="language.types.declarations">déclarations de type</link>.
|
||
Différents types pris en charge par le système de types de PHP sont disponibles sur la
|
||
<link linkend="language.types.type-system">page du système de types</link>.
|
||
</para>
|
||
|
||
<para>
|
||
Les types limitent le type d'opérations qui peuvent être effectuées sur eux.
|
||
Cependant, si une expression/variable est utilisée dans une opération que
|
||
son type ne supporte pas, PHP tentera de
|
||
<link linkend="language.types.type-juggling">jongler de type</link> dans un
|
||
type compatible avec l'opération.
|
||
Ce processus dépend du contexte dans lequel la valeur est utilisée.
|
||
Pour plus d’informations, consulter la section sur le
|
||
<link linkend="language.types.type-juggling">jonglage de type</link>.
|
||
</para>
|
||
|
||
<tip>
|
||
<simpara>
|
||
<link linkend="types.comparisons">Les tableaux de comparaison de type</link>
|
||
peuvent également être utiles, car divers exemples de comparaison entre des
|
||
valeurs de différents types sont présents.
|
||
</simpara>
|
||
</tip>
|
||
|
||
<note>
|
||
<simpara>
|
||
Il est possible de forcer l’évaluation d’une expression à un certain type en
|
||
utilisant un <link linkend="language.types.typecasting">type casting</link>.
|
||
Une variable peut également être convertie sur place à l’aide de la fonction
|
||
<function>settype</function>.
|
||
</simpara>
|
||
</note>
|
||
|
||
<para>
|
||
Pour vérifier le type et la valeur d'une
|
||
<link linkend="language.expressions">expression</link>, utiliser la fonction
|
||
<function>var_dump</function>.
|
||
|
||
Pour récupérer le type d'une
|
||
<link linkend="language.expressions">expression</link>,
|
||
utiliser la fonction <function>get_debug_type</function>.
|
||
Toutefois, pour vérifier si une expression est d'un certain type, utiliser
|
||
plutôt les fonctions
|
||
<!-- TODO When PhD support is there: <function>is_<replaceable>type</replaceable></function> -->
|
||
<literal>is_<replaceable>type</replaceable></literal>.
|
||
|
||
|
||
<example>
|
||
<title>Types Différents</title>
|
||
<programlisting role="php">
|
||
<![CDATA[
|
||
<?php
|
||
$a_bool = TRUE; // un booléen
|
||
$a_str = "foo"; // une chaîne de caractères
|
||
$a_str2 = 'foo'; // une chaîne de caractères
|
||
$an_int = 12; // un entier
|
||
|
||
echo get_debug_type($a_bool), "\n";
|
||
echo get_debug_type($a_str), "\n";
|
||
|
||
// Si c'est un entier, incrément de 4
|
||
if (is_int($an_int)) {
|
||
$an_int += 4;
|
||
}
|
||
var_dump($an_int);
|
||
|
||
// Si $a_bool est une chaîne de caractères, on l'affiche
|
||
if (is_string($a_bool)) {
|
||
echo "String: $a_bool";
|
||
}
|
||
?>
|
||
]]>
|
||
</programlisting>
|
||
&example.outputs.8;
|
||
<screen>
|
||
<![CDATA[
|
||
bool
|
||
string
|
||
int(16)
|
||
]]>
|
||
</screen>
|
||
</example>
|
||
</para>
|
||
<note>
|
||
<simpara>
|
||
Avant PHP 8.0.0, lorsque le <function>get_debug_type</function> n’est pas
|
||
disponible, la fonction <function>gettype</function> peut être utilisée à
|
||
la place.
|
||
Cependant, elle n’utilise pas les noms de type canoniques.
|
||
</simpara>
|
||
</note>
|
||
</sect1>
|
||
|
||
&language.types.type-system;
|
||
&language.types.null;
|
||
&language.types.boolean;
|
||
&language.types.integer;
|
||
&language.types.float;
|
||
&language.types.string;
|
||
&language.types.numeric-strings;
|
||
&language.types.array;
|
||
&language.types.object;
|
||
&language.types.enumerations;
|
||
&language.types.resource;
|
||
&language.types.callable;
|
||
&language.types.mixed;
|
||
&language.types.void;
|
||
&language.types.never;
|
||
&language.types.relative-class-types;
|
||
&language.types.singleton;
|
||
&language.types.iterable;
|
||
&language.types.declarations;
|
||
&language.types.type-juggling;
|
||
|
||
</chapter>
|
||
|
||
<!-- Keep this comment at the end of the file
|
||
Local variables:
|
||
mode: sgml
|
||
sgml-omittag:t
|
||
sgml-shorttag:t
|
||
sgml-minimize-attributes:nil
|
||
sgml-always-quote-attributes:t
|
||
sgml-indent-step:1
|
||
sgml-indent-data:t
|
||
indent-tabs-mode:nil
|
||
sgml-parent-document:nil
|
||
sgml-default-dtd-file:"~/.phpdoc/manual.ced"
|
||
sgml-exposed-tags:nil
|
||
sgml-local-catalogs:nil
|
||
sgml-local-ecat-files:nil
|
||
End:
|
||
vim600: syn=xml fen fdm=syntax fdl=2 si
|
||
vim: et tw=78 syn=sgml
|
||
vi: ts=1 sw=1
|
||
-->
|