-
Notifications
You must be signed in to change notification settings - Fork 105
/
Copy pathmktime.xml
executable file
·244 lines (232 loc) · 8.18 KB
/
mktime.xml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
<?xml version="1.0" encoding="utf-8"?>
<!-- $Revision$ -->
<!-- EN-Revision: 349e3c6502e0bbeb15aef2b4a4a25f3f5e10fbfe Maintainer: HonestQiao Status: ready -->
<!-- CREDITS: mowangjuanzi, Luffy -->
<refentry xml:id="function.mktime" xmlns="http://docbook.org/ns/docbook">
<refnamediv>
<refname>mktime</refname>
<refpurpose>取得一个日期的 Unix 时间戳</refpurpose>
</refnamediv>
<refsect1 role="description">
&reftitle.description;
<methodsynopsis>
<type class="union"><type>int</type><type>false</type></type><methodname>mktime</methodname>
<methodparam><type>int</type><parameter>hour</parameter></methodparam>
<methodparam choice="opt"><type class="union"><type>int</type><type>null</type></type><parameter>minute</parameter><initializer>&null;</initializer></methodparam>
<methodparam choice="opt"><type class="union"><type>int</type><type>null</type></type><parameter>second</parameter><initializer>&null;</initializer></methodparam>
<methodparam choice="opt"><type class="union"><type>int</type><type>null</type></type><parameter>month</parameter><initializer>&null;</initializer></methodparam>
<methodparam choice="opt"><type class="union"><type>int</type><type>null</type></type><parameter>day</parameter><initializer>&null;</initializer></methodparam>
<methodparam choice="opt"><type class="union"><type>int</type><type>null</type></type><parameter>year</parameter><initializer>&null;</initializer></methodparam>
</methodsynopsis>
<para>
根据给出的参数返回 Unix 时间戳。时间戳是一个长整数,包含了从
Unix 纪元(January 1 1970 00:00:00 GMT)到给定时间的秒数。
</para>
<para>
任何可选或为 &null; 的参数都将根据本地日期和时间设置为当前值。
</para>
<warning>
<para>
请注意,参数的顺序是很奇怪:<parameter>month</parameter>、<parameter>day</parameter>、<parameter>year</parameter>,而不是更合理的
<parameter>year</parameter>、<parameter>month</parameter>、<parameter>day</parameter> 顺序。
</para>
</warning>
<simpara>
不带参数调用 <function>mktime</function> 已经不受支持,会导致 <classname>ArgumentCountError</classname>。
<function>time</function> 可以用来获取当前时间戳。
</simpara>
</refsect1>
<refsect1 role="parameters">
&reftitle.parameters;
<para>
<variablelist>
<varlistentry>
<term><parameter>hour</parameter></term>
<listitem>
<para>
相对于一天开始的小时数,由 <parameter>month</parameter>、<parameter>day</parameter> 和
<parameter>year</parameter> 确定。负值是指当天零点前的小时。值大于 23 是指接下来几天的适当小时。
</para>
</listitem>
</varlistentry>
<varlistentry>
<term><parameter>minute</parameter></term>
<listitem>
<para>
相对于 <parameter>hour</parameter> 开始的分钟数。负值指的是上个小时的分钟。大于 59
的值将指向接下来几个小时的适当分钟。
</para>
</listitem>
</varlistentry>
<varlistentry>
<term><parameter>second</parameter></term>
<listitem>
<para>
相对于 <parameter>minute</parameter> 开始的秒数。负值是指前一分钟的秒数。大于 59
的值是指接下来几分钟的适当秒。
</para>
</listitem>
</varlistentry>
<varlistentry>
<term><parameter>month</parameter></term>
<listitem>
<para>
相对于去年年底的月份数。值 1 到 12 是指相关年份的正常日历月份。小于 1
的值(包括负值)按相反的顺序指向去年的月份,因此 0 是 12 月,-1 是 11
月,以此类推。值大于 12 是指接下来几年的适当月份。
</para>
</listitem>
</varlistentry>
<varlistentry>
<term><parameter>day</parameter></term>
<listitem>
<para>
相对于上个月月底的天数。值 1 到 28、29、30 或 31(取决于月份)是指相关月份的正常天数。小于
1 的值(包括负值)是指上个月的天数,因此 0 是上个月的最后一天,-1
是倒数第二天,以此类推。大于相关月份天数的值是指接下来几个月的适当某一天。
</para>
</listitem>
</varlistentry>
<varlistentry>
<term><parameter>year</parameter></term>
<listitem>
<para>
年份数,可以是两位或四位数字,0-69 对应于 2000-2069,70-100
对应于 1970-2000。在如今系统中普遍把 time_t 作为一个 32
位有符号整数的情况下,<parameter>year</parameter>
的合法范围是 1901 到 2038 之间。
</para>
</listitem>
</varlistentry>
</variablelist>
</para>
</refsect1>
<refsect1 role="returnvalues">
&reftitle.returnvalues;
<para>
<function>mktime</function> 根据给出的参数返回 Unix 时间戳,如果时间戳不适合 PHP 整数则返回 &false;。
</para>
</refsect1>
<refsect1 role="changelog">
&reftitle.changelog;
<para>
<informaltable>
<tgroup cols="2">
<thead>
<row>
<entry>&Version;</entry>
<entry>&Description;</entry>
</row>
</thead>
<tbody>
<row>
<entry>8.0.0</entry>
<entry>
<parameter>hour</parameter> 不再可选。如果需要 Unix 时间戳,可以使用 <function>time</function>。
</entry>
</row>
<row>
<entry>8.0.0</entry>
<entry>
现在 <parameter>minute</parameter>、<parameter>second</parameter>、<parameter>month</parameter>、<parameter>day</parameter>
和 <parameter>year</parameter> 允许为 null。
</entry>
</row>
</tbody>
</tgroup>
</informaltable>
</para>
</refsect1>
<refsect1 role="examples">
&reftitle.examples;
<para>
<example>
<title>基本例子 </title>
<programlisting role="php">
<![CDATA[
<?php
// 设置使用的默认时区。
date_default_timezone_set('UTC');
// 打印:July 1, 2000 is on a Saturday
echo "July 1, 2000 is on a " . date("l", mktime(0, 0, 0, 7, 1, 2000));
// 打印类似的东西:2006-04-05T01:02:03+00:00
echo date('c', mktime(1, 2, 3, 4, 5, 2006));
?>
]]>
</programlisting>
</example>
</para>
<para>
<example>
<title><function>mktime</function> 例子</title>
<para>
<function>mktime</function>
在做日期计算和验证方面很有用,它会自动计算超出范围的输入的正确值。例如下面例子中每一行都会产生字符串
"Jan-01-1998"。
</para>
<programlisting role="php">
<![CDATA[
<?php
echo date("M-d-Y", mktime(0, 0, 0, 12, 32, 1997));
echo date("M-d-Y", mktime(0, 0, 0, 13, 1, 1997));
echo date("M-d-Y", mktime(0, 0, 0, 1, 1, 1998));
echo date("M-d-Y", mktime(0, 0, 0, 1, 1, 98));
?>
]]>
</programlisting>
</example>
</para>
<para>
<example>
<title>下个月的最后一天</title>
<para>
任何给定月份的最后一天都可以被表示为下个月的第 "0"
天,而不是 -1 天。下面两个例子都会产生字符串
"The last day in Feb 2000 is: 29"。
</para>
<programlisting role="php">
<![CDATA[
<?php
$lastday = mktime(0, 0, 0, 3, 0, 2000);
echo 'Last day in Feb 2000 is: ', date('d', $lastday);
$lastday = mktime(0, 0, 0, 4, -31, 2000);
echo 'Last day in Feb 2000 is: ', date('d', $lastday);
?>
]]>
</programlisting>
</example>
</para>
</refsect1>
<refsect1 role="seealso">
&reftitle.seealso;
<para>
<simplelist>
<member><classname>DateTimeImmutable</classname> 类</member>
<member><function>checkdate</function></member>
<member><function>gmmktime</function></member>
<member><function>date</function></member>
<member><function>time</function></member>
</simplelist>
</para>
</refsect1>
</refentry>
<!-- 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
-->