PHP date_create_immutable() 函数



定义和用法

date_create_immutable()DateTimeImmutable::__construct() 的别名。此函数接受日期/时间字符串和时区作为参数(可选),并创建一个 DateTimeImmutable 对象。

与 DateTime 对象不同,此对象不允许任何修改,它会在更改时创建一个新对象并返回它。默认情况下,此函数创建当前日期/时间的对象。

语法

date_create_immutable([$date_time, $timezone]);

参数

序号 参数和描述
1

date_time (可选)

这是您需要为其创建不可变 DateTime 对象的日期/时间字符串(以支持的格式)。

2

timezone (可选)

这表示给定时间的时区。

返回值

PHP date_create_immutable() 函数返回创建的 DateTimeImmutable 对象。

PHP 版本

此函数在 PHP 5.5.0 版本中首次引入,并且适用于所有更高版本。

示例

以下示例演示了 date_create_immutable() 函数的使用:

<?php
   $date_string = "2019-08-15 9:25:45";
   $immutable = date_create_immutable($date_string);   
   print_r($immutable);
?>

这将产生以下结果:

DateTimeImmutable Object
(
    [date] => 2019-08-15 09:25:45.000000
    [timezone_type] => 3
    [timezone] => UTC
)

示例

以下是带有时区参数的 date_create_immutable() 示例:

<?php
   $date_string = "2019-08-15 9:25:45";
   $tz = new DateTimeZone('Indian/Mahe');
   $immutable = date_create_immutable($date_string, $tz);   
   print_r($immutable);   
   print( date_format($immutable,'Y-m-d H:i:s')); 
?>

这将产生以下结果:

DateTimeImmutable Object
(
    [date] => 2019-08-15 09:25:45.000000
    [timezone_type] => 3
    [timezone] => Indian/Mahe
)
2019-08-15 09:25:45

示例

在以下示例中,我们创建了一个不可变日期和普通日期对象,向它们添加了间隔并显示了结果值。由于不可变 DateTime 对象会在尝试更改时创建并返回一个新对象,因此您可以观察到它在更改前后有所不同:

<?php
   print("Immutable Date: "."\n");
   $date1 = date_create_immutable('1986-09-11');
   $date2 = $date1->add(new DateInterval('P15DP12MP9YT24H'));
   print("Original Object Value: ".$date1->format('Y-m-d')."\n");
   print("After Change: ".$date2->format('Y-m-d')."\n");
   print("Normal Date: "."\n");
   $date3 = date_create('1986-09-11');
   $date4 = $date3->add(new DateInterval('P15DP12MP9YT24H'));
   print("Original Object Value: ".$date3->format('Y-m-d')."\n");
   print("After Change: ".$date4->format('Y-m-d')."\n");
?>

这将产生以下结果:

Immutable Date:
Original Object Value: 1986-09-11
After Change: 1996-09-27
Normal Date:
Original Object Value: 1996-09-27
After Change: 1996-09-27
php_function_reference.htm
广告