<?php
include_once $_SERVER['DOCUMENT_ROOT'] . '/include/shared-manual.inc';
$TOC = array();
$TOC_DEPRECATED = array();
$PARENTS = array();
include_once dirname(__FILE__) ."/toc/book.datetime.inc";
$setup = array (
  'home' => 
  array (
    0 => 'index.php',
    1 => 'PHP Manual',
  ),
  'head' => 
  array (
    0 => 'UTF-8',
    1 => 'ru',
  ),
  'this' => 
  array (
    0 => 'class.dateinterval.php',
    1 => 'DateInterval',
    2 => 'Класс DateInterval',
  ),
  'up' => 
  array (
    0 => 'book.datetime.php',
    1 => 'Дата и время',
  ),
  'prev' => 
  array (
    0 => 'datetimezone.listidentifiers.php',
    1 => 'DateTimeZone::listIdentifiers',
  ),
  'next' => 
  array (
    0 => 'dateinterval.construct.php',
    1 => 'DateInterval::__construct',
  ),
  'alternatives' => 
  array (
  ),
  'source' => 
  array (
    'lang' => 'ru',
    'path' => 'reference/datetime/dateinterval.xml',
  ),
  'history' => 
  array (
  ),
  'extra_header_links' => 
  array (
    'rel' => 'alternate',
    'href' => '/manual/en/feeds/class.dateinterval.atom',
    'type' => 'application/atom+xml',
  ),
);
$setup["toc"] = $TOC;
$setup["toc_deprecated"] = $TOC_DEPRECATED;
$setup["parents"] = $PARENTS;
manual_setup($setup);

contributors($setup);

?>
<div id="class.dateinterval" class="reference">

 <h1 class="title">Класс DateInterval</h1>
 

 <div class="partintro"><p class="verinfo">(PHP 5 &gt;= 5.3.0, PHP 7, PHP 8)</p>

  
  <div class="section" id="dateinterval.intro">
   <h2 class="title">Введение</h2>
   <p class="para">
    Представляет интервалы дат.
   </p>
   <p class="para">
    Интервал дат хранит либо определённое фиксированное время
    (в годах, месяцах, днях, часах и т.д.) или относительную строку времени в формате, поддерживаемом
    конструктором <span class="classname"><a href="class.datetimeimmutable.php" class="classname">DateTimeImmutable</a></span> и <span class="classname"><a href="class.datetime.php" class="classname">DateTime</a></span>.
   </p>
   <p class="para">
    Более конкретно, информация в объекте класса
    <span class="classname"><strong class="classname">DateInterval</strong></span> является инструкцией для перехода от одной даты/времени к другой дате/времени. Этот процесс не всегда обратим.
   </p>
   <p class="para">
    Распространённым способом создания объекта <span class="classname"><strong class="classname">DateInterval</strong></span>
    является вычисление разницы между двумя объектами даты/времени с помощью
    <span class="methodname"><a href="datetime.diff.php" class="methodname">DateTimeInterface::diff()</a></span>.
   </p>
   <p class="para">
    Поскольку не существует чётко определённого способа сравнения интервалов дат,
    экземпляры <span class="classname"><strong class="classname">DateInterval</strong></span> являются
    <a href="language.operators.comparison.php#language.operators.comparison.incomparable" class="link">несравнимыми</a>.
   </p>
  </div>
  

  <div class="section" id="dateinterval.synopsis">
   <h2 class="title">Обзор класса</h2>


   <div class="classsynopsis"><div class="classsynopsisinfo">
    
     <span class="modifier">class</span> <strong class="classname"><strong class="classname">DateInterval</strong></strong>
     {</div>

    <div class="classsynopsisinfo classsynopsisinfo_comment">/* Свойства */</div>
    <div class="fieldsynopsis">
     <span class="modifier">public</span>
     <span class="type"><a href="language.types.integer.php" class="type int">int</a></span>
      <var class="varname"><a href="class.dateinterval.php#dateinterval.props.y">$<var class="varname">y</var></a></var>;</div>

    <div class="fieldsynopsis"><span class="modifier">public</span>
     <span class="type"><a href="language.types.integer.php" class="type int">int</a></span>
      <var class="varname"><a href="class.dateinterval.php#dateinterval.props.m">$<var class="varname">m</var></a></var>;</div>

    <div class="fieldsynopsis"><span class="modifier">public</span>
     <span class="type"><a href="language.types.integer.php" class="type int">int</a></span>
      <var class="varname"><a href="class.dateinterval.php#dateinterval.props.d">$<var class="varname">d</var></a></var>;</div>

    <div class="fieldsynopsis"><span class="modifier">public</span>
     <span class="type"><a href="language.types.integer.php" class="type int">int</a></span>
      <var class="varname"><a href="class.dateinterval.php#dateinterval.props.h">$<var class="varname">h</var></a></var>;</div>

    <div class="fieldsynopsis"><span class="modifier">public</span>
     <span class="type"><a href="language.types.integer.php" class="type int">int</a></span>
      <var class="varname"><a href="class.dateinterval.php#dateinterval.props.i">$<var class="varname">i</var></a></var>;</div>

    <div class="fieldsynopsis"><span class="modifier">public</span>
     <span class="type"><a href="language.types.integer.php" class="type int">int</a></span>
      <var class="varname"><a href="class.dateinterval.php#dateinterval.props.s">$<var class="varname">s</var></a></var>;</div>

    <div class="fieldsynopsis"><span class="modifier">public</span>
     <span class="type"><a href="language.types.float.php" class="type float">float</a></span>
      <var class="varname"><a href="class.dateinterval.php#dateinterval.props.f">$<var class="varname">f</var></a></var>;</div>

    <div class="fieldsynopsis"><span class="modifier">public</span>
     <span class="type"><a href="language.types.integer.php" class="type int">int</a></span>
      <var class="varname"><a href="class.dateinterval.php#dateinterval.props.invert">$<var class="varname">invert</var></a></var>;</div>

    <div class="fieldsynopsis"><span class="modifier">public</span>
     <span class="type"><a href="language.types.mixed.php" class="type mixed">mixed</a></span>
      <var class="varname"><a href="class.dateinterval.php#dateinterval.props.days">$<var class="varname">days</var></a></var>;</div>

    <div class="fieldsynopsis"><span class="modifier">public</span>
     <span class="type"><a href="language.types.boolean.php" class="type bool">bool</a></span>
      <var class="varname"><a href="class.dateinterval.php#dateinterval.props.from-string">$<var class="varname">from_string</var></a></var>;</div>

    <div class="fieldsynopsis"><span class="modifier">public</span>
     <span class="type"><a href="language.types.string.php" class="type string">string</a></span>
      <var class="varname"><a href="class.dateinterval.php#dateinterval.props.date-string">$<var class="varname">date_string</var></a></var>;</div>


    <div class="classsynopsisinfo classsynopsisinfo_comment">/* Методы */</div>
    <div class="constructorsynopsis dc-description">
   <span class="modifier">public</span> <span class="methodname"><a href="dateinterval.construct.php" class="methodname">__construct</a></span>(<span class="methodparam"><span class="type"><a href="language.types.string.php" class="type string">string</a></span> <code class="parameter">$duration</code></span>)</div>

    <div class="methodsynopsis dc-description"><span class="modifier">public</span> <span class="modifier">static</span> <span class="methodname"><a href="dateinterval.createfromdatestring.php" class="methodname">createFromDateString</a></span>(<span class="methodparam"><span class="type"><a href="language.types.string.php" class="type string">string</a></span> <code class="parameter">$datetime</code></span>): <span class="type"><a href="class.dateinterval.php" class="type DateInterval">DateInterval</a></span></div>
<div class="methodsynopsis dc-description"><span class="modifier">public</span> <span class="methodname"><a href="dateinterval.format.php" class="methodname">format</a></span>(<span class="methodparam"><span class="type"><a href="language.types.string.php" class="type string">string</a></span> <code class="parameter">$format</code></span>): <span class="type"><a href="language.types.string.php" class="type string">string</a></span></div>

   }</div>


  </div>

  <div class="section" id="dateinterval.props">
   <h2 class="title">Свойства</h2>
   <div class="warning"><strong class="warning">Внимание</strong>
    <p class="para">
     Доступные свойства, перечисленные ниже, зависят от версии PHP
     и должны рассматриваться как <em>доступные только для чтения</em>.
    </p>
   </div>
   <dl>
    
     <dt id="dateinterval.props.y"><var class="varname">y</var></dt>
     <dd>
      <p class="para">
       Количество лет.
      </p>
     </dd>
    
    
     <dt id="dateinterval.props.m"><var class="varname">m</var></dt>
     <dd>
      <p class="para">
       Количество месяцев.
      </p>
     </dd>
    
    
     <dt id="dateinterval.props.d"><var class="varname">d</var></dt>
     <dd>
      <p class="para">
       Количество дней.
      </p>
     </dd>
    
    
     <dt id="dateinterval.props.h"><var class="varname">h</var></dt>
     <dd>
      <p class="para">
       Количество часов.
      </p>
     </dd>
    
    
     <dt id="dateinterval.props.i"><var class="varname">i</var></dt>
     <dd>
      <p class="para">
       Количество минут.
      </p>
     </dd>
    
    
     <dt id="dateinterval.props.s"><var class="varname">s</var></dt>
     <dd>
      <p class="para">
       Количество секунд.
      </p>
     </dd>
    
    
     <dt id="dateinterval.props.f"><var class="varname">f</var></dt>
     <dd>
      <p class="para">
       Количество микросекунд в виде долей секунды.
      </p>
     </dd>
    
    
     <dt id="dateinterval.props.invert"><var class="varname">invert</var></dt>
     <dd>
      <p class="para">
       Принимает <code class="literal">1</code>, если интервал представляет
       отрицательный период времени и
       <code class="literal">0</code> в противном случае. Смотрите
       <span class="methodname"><a href="dateinterval.format.php" class="methodname">DateInterval::format()</a></span>.
      </p>
     </dd>
    
    
     <dt id="dateinterval.props.days"><var class="varname">days</var></dt>
     <dd>
      <p class="para">
       Если объект DateInterval создан методом
       <span class="methodname"><a href="datetime.diff.php" class="methodname">DateTimeImmutable::diff()</a></span> или <span class="methodname"><a href="datetime.diff.php" class="methodname">DateTime::diff()</a></span>,
       то это общее количество полных дней между начальной и конечной датами
       В противном случае <var class="varname">days</var> примет значение <strong><code><a href="reserved.constants.php#constant.false">false</a></code></strong>.
      </p>
     </dd>
    
    
     <dt id="dateinterval.props.from-string"><var class="varname">from_string</var></dt>
     <dd>
      <p class="para">
       Если объект DateInterval был создан методом <span class="methodname"><a href="dateinterval.createfromdatestring.php" class="methodname">DateInterval::createFromDateString()</a></span>,
       то значение свойства будет <strong><code><a href="reserved.constants.php#constant.true">true</a></code></strong> и свойство <var class="varname">date_string</var> будет заполнено.
       В противном случае значение свойства будет <strong><code><a href="reserved.constants.php#constant.false">false</a></code></strong>
       и свойства от <var class="varname">y</var> до <var class="varname">f</var>, <var class="varname">invert</var> и <var class="varname">days</var> будут заполнены.
      </p>
     </dd>
    
    
     <dt id="dateinterval.props.date-string"><var class="varname">date_string</var></dt>
     <dd>
      <p class="para">
       Строка, используемая в качестве аргумента метода <span class="methodname"><a href="dateinterval.createfromdatestring.php" class="methodname">DateInterval::createFromDateString()</a></span>.
      </p>
     </dd>
    
   </dl>
  </div>

  <div class="section" id="dateinterval.changelog">
   <h2 class="title">Список изменений</h2>
 <p class="para">
  <table class="doctable informaltable">
   
    <thead>
     <tr>
      <th>Версия</th>
      <th>Описание</th>
     </tr>

    </thead>

    <tbody class="tbody">
     <tr>
      <td>8.2.0</td>
      <td>
       Добавлены свойства <var class="varname">from_string</var> и <var class="varname">date_string</var> для экземпляров <span class="classname"><strong class="classname">DateInterval</strong></span>,
       которые были созданы с помощью метода <span class="methodname"><a href="dateinterval.createfromdatestring.php" class="methodname">DateInterval::createFromDateString()</a></span>.
      </td>
     </tr>

     <tr>
      <td>8.2.0</td>
      <td>
       Будут видны только значения от <code class="literal">y</code> до <code class="literal">f</code>,
       <code class="literal">invert</code> и <code class="literal">days</code>.
      </td>
     </tr>

     <tr>
      <td>7.4.0</td>
      <td>
       Экземпляры <span class="classname"><strong class="classname">DateInterval</strong></span> теперь несравнимы;
       ранее все экземпляры <span class="classname"><strong class="classname">DateInterval</strong></span> считались равными.
      </td>
     </tr>

     <tr>
      <td>7.1.0</td>
      <td>Добавлено свойство <var class="varname">f</var>.</td>
     </tr>

    </tbody>
   
  </table>

 </p>
  </div>
 </div>

 


















<h2>Содержание</h2><ul class="chunklist chunklist_reference"><li><a href="dateinterval.construct.php">DateInterval::__construct</a> — Создаёт новый объект DateInterval</li><li><a href="dateinterval.createfromdatestring.php">DateInterval::createFromDateString</a> — Создаёт объект класса DateInterval из даты в относительном формате</li><li><a href="dateinterval.format.php">DateInterval::format</a> — Форматирует интервал</li></ul>
</div>
<?php manual_footer($setup); ?>