mirror of
https://github.com/php/doc-ja.git
synced 2026-03-23 22:52:11 +01:00
160 lines
5.0 KiB
XML
160 lines
5.0 KiB
XML
<?xml version="1.0" encoding="utf-8"?>
|
|
<!-- $Revision$ -->
|
|
<!-- EN-Revision: e587d0655e426f97b3fcb431453da5030e743b23 Maintainer: mumumu Status: ready -->
|
|
<chapter xml:id="language.types" xmlns="http://docbook.org/ns/docbook" annotations="interactive">
|
|
<title>型</title>
|
|
|
|
<sect1 xml:id="language.types.intro">
|
|
<title>はじめに</title>
|
|
|
|
<para>
|
|
PHP における単一の式はそれぞれ、
|
|
その値に応じて、以下の組み込み型のうちのひとつを持ちます:
|
|
<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> (浮動小数点数)</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 は、動的に型付けを行う言語です。
|
|
これは、PHP が実行時に型を決定するため、
|
|
デフォルトでは変数の型を指定する必要がないということです。
|
|
しかし、
|
|
<link linkend="language.types.declarations">型宣言</link> を使うことで、
|
|
その一部に静的に型を指定することができます。
|
|
</para>
|
|
|
|
<para>
|
|
型は、それに対して行える操作を制限します。
|
|
しかし、式や変数に対して、型がサポートしていない操作を行うと、
|
|
PHP はその操作をサポートする
|
|
<link linkend="language.types.type-juggling">型に変換</link> しようとします。
|
|
この処理は、値が使われる文脈によって異なります。
|
|
詳細は
|
|
<link linkend="language.types.type-juggling">型の相互変換</link>
|
|
のページを参照ください。
|
|
</para>
|
|
|
|
<tip>
|
|
<simpara>
|
|
<link linkend="types.comparisons">型の比較表</link>
|
|
も役に立つかもしれません。
|
|
さまざまな型の値の比較に関する例があります。
|
|
</simpara>
|
|
</tip>
|
|
|
|
<note>
|
|
<simpara>
|
|
ある式を強制的に他の型として評価させたい場合、
|
|
<link linkend="language.types.typecasting">型キャスト</link> を使います。
|
|
<function>settype</function> 関数を変数に対して使うと、
|
|
変数の型をその場で変換できます。
|
|
</simpara>
|
|
</note>
|
|
|
|
<para>
|
|
<link linkend="language.expressions">式</link>の型と値を知りたい場合は、
|
|
<function>var_dump</function> 関数を使用してください。
|
|
<link linkend="language.expressions">式</link> の型を知りたい場合は、
|
|
<function>get_debug_type</function> を使用してください。
|
|
式がある型であるかどうかをチェックするには
|
|
<!-- TODO When PhD support is there: <function>is_<replaceable>type</replaceable></function> -->
|
|
<literal>is_<replaceable>type</replaceable></literal>
|
|
関数を代わりに使用してください。
|
|
<example>
|
|
<title>異なる型</title>
|
|
<programlisting role="php">
|
|
<![CDATA[
|
|
<?php
|
|
$a_bool = true; // bool
|
|
$a_str = "foo"; // string
|
|
$a_str2 = 'foo'; // string
|
|
$an_int = 12; // int
|
|
|
|
echo get_debug_type($a_bool), "\n";
|
|
echo get_debug_type($a_str), "\n";
|
|
|
|
// 数値であれば、4を足す
|
|
if (is_int($an_int)) {
|
|
$an_int += 4;
|
|
}
|
|
var_dump($an_int);
|
|
|
|
// $a_bool が文字列であれば, それをprintする
|
|
if (is_string($a_bool)) {
|
|
echo "String: $a_bool";
|
|
}
|
|
?>
|
|
]]>
|
|
</programlisting>
|
|
&example.outputs.8;
|
|
<screen>
|
|
<![CDATA[
|
|
bool
|
|
string
|
|
int(16)
|
|
]]>
|
|
</screen>
|
|
</example>
|
|
</para>
|
|
<note>
|
|
<simpara>
|
|
PHP 8.0.0 より前のバージョンでは、
|
|
<function>get_debug_type</function> が使えません。
|
|
代わりに <function>gettype</function> が使えますが、
|
|
この関数は正規化された型の名前を使いません。
|
|
</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
|
|
-->
|