编辑这个页面须要登录或更高权限!
date_create_immutable()函数返回新的DateTimeImmutable对象
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版本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("不可变的日期: "."\n"); $date1 = date_create_immutable('1986-09-11'); $date2 = $date1->add(new DateInterval('P15DP12MP9YT24H')); print("原始对象值: ".$date1->format('Y-m-d')."\n"); print("变更后: ".$date2->format('Y-m-d')."\n"); print("正常日期: "."\n"); $date3 = date_create('1986-09-11'); $date4 = $date3->add(new DateInterval('P15DP12MP9YT24H')); print("原始对象值: ".$date3->format('Y-m-d')."\n"); print("变更后: ".$date4->format('Y-m-d')."\n"); ?>测试看看‹/›
输出结果
不可变的日期: 原始对象值: 1986-09-11 变更后: 1996-09-27 正常日期: 原始对象值: 1996-09-27 变更后: 1996-09-27