1
0
mirror of https://github.com/php/doc-ru.git synced 2026-03-26 00:32:15 +01:00
Files
archived-doc-ru/language/predefined/stringable.xml
2024-07-07 19:21:04 +03:00

117 lines
3.7 KiB
XML
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
<?xml version="1.0" encoding="utf-8"?>
<!-- EN-Revision: 3e519f4d1cd5dc0af3bf894bb32416f682a507d5 Maintainer: sergey Status: ready -->
<!-- Reviewed: no -->
<reference xml:id="class.stringable" role="class" xmlns="http://docbook.org/ns/docbook" xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:xi="http://www.w3.org/2001/XInclude">
<title>Интерфейс Stringable</title>
<titleabbrev>Stringable</titleabbrev>
<partintro>
<!-- {{{ Stringable intro -->
<section xml:id="stringable.intro">
&reftitle.intro;
<para>
Интерфейс <interfacename>Stringable</interfacename> обозначает класс,
который реализует метод <link linkend="object.tostring">__toString()</link>. В отличие от большинства интерфейсов,
<interfacename>Stringable</interfacename> неявно присутствует в каждом классе,
в котором определили магический метод <link linkend="object.tostring">__toString()</link>,
хотя интерфейс разрешается и требуется объявлять явно.
</para>
<para>
Основное значение интерфейса — разрешить функциям выполнять проверку типа на соответствие объединённым типам
<literal>string|Stringable</literal>, чтобы принимать либо строковый примитив,
либо объект, который может преобразовать в строку.
</para>
</section>
<!-- }}} -->
<section xml:id="stringable.synopsis">
&reftitle.interfacesynopsis;
<!-- {{{ Synopsis -->
<classsynopsis class="interface">
<oointerface>
<interfacename>Stringable</interfacename>
</oointerface>
<classsynopsisinfo role="comment">&Methods;</classsynopsisinfo>
<xi:include xpointer="xmlns(db=http://docbook.org/ns/docbook) xpointer(id('class.stringable')/db:refentry/db:refsect1[@role='description']/descendant::db:methodsynopsis[@role='Stringable'])">
<xi:fallback/>
</xi:include>
</classsynopsis>
<!-- }}} -->
</section>
<section xml:id="stringable.examples">
<title>Примеры использования интерфейса Stringable</title>
<para>
<example xml:id="stringable.basic-example">
<title>Простой пример использования интерфейса Stringable</title>
<programlisting role="php">
<![CDATA[
<?php
class IPv4Address implements Stringable {
public function __construct(
private string $oct1,
private string $oct2,
private string $oct3,
private string $oct4,
) {}
public function __toString(): string
{
return "$this->oct1.$this->oct2.$this->oct3.$this->oct4";
}
}
function showStuff(string|Stringable $value)
{
// Вывод значения с типом Stringable будет неявно вызывать метод __toString
print $value;
}
$ip = new IPv4Address('123', '234', '42', '9');
showStuff($ip);
?>
]]>
</programlisting>
&example.outputs.similar;
<screen>
<![CDATA[
123.234.42.9
]]>
</screen>
</example>
</para>
</section>
</partintro>
&language.predefined.stringable.tostring;
</reference>
<!-- 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
-->