A.输出数字0 ?$ ^& k8 V0 t
B.输出数字-1 k7 c3 W* g. ~6 u( u4 R* M' x% r# p
C.输出数字1 ) b/ y+ S m- j* q2 i. ~" B0 `D.报错 7 o0 I7 q O) [" w) AE.什么都不输出 ( t8 ^$ q2 m2 u. t! d2 h( O% O) T3 E% i
' f- m( B5 w+ E/ q3 |; t
9.以下哪个选项对time函数的描述最准确? 9 j) R0 P( K( C/ ^* _* j" c" E& ~ n; H- D4 o) \6 }* l0 [( O5 B) T
A.返回从UNIX纪元开始到现在经过的秒数 / W) H7 Y) w. c6 B+ r9 Q- UB.以GMT时区为基准,返回从UNIX纪元开始到现在经过的秒数: l- M* k- `4 Z+ K8 G$ e* \8 t3 V! K
C.以本地时区为基准,返回从UNIX纪元开始到现在经过的秒数) s7 i: T8 N' I* B
D.计算从UNIX纪元开始经过的时间,并以整型数字表示 ( ]3 s9 \( q5 c& C$ KE.以上都对% I: o4 f1 |9 u0 }* U/ v
5 ^% Z) |+ c* U2 T' g$ o, S5 S 9 c _- ?- Y& s: q2 z/ m/ q" f" h10.以下脚本输出什么?
<?php
$time = strtotime ('2004/01/01');
echo date ('H:\i:s', $time);
?>
复制代码
A.00:00:00 & m% u* v" O+ \) l. {5 Y9 o$ uB.12:00:00- o3 {4 O7 V% k0 }
C.00:i:00( k7 d3 L# ]( g+ b
D.12:i:007 B4 P7 h: v9 ?4 T' u
E.-1 " X" [: z0 G2 h& N7 l # r1 }' P& z: G8 ]' i& f* e% t1 x) N' B6 q
11.以下哪个表达式能让cookie在一小时后过期(假设客户端的时间和时区设置都正确,并且客户端与服务器不在同一个时区)? $ `; C6 V# z8 q* @# u' E6 ^2 @0 ^ 7 Z9 Q5 n. T* B$ O" J8 ?A.time() + 3600: F- p0 ~( P4 C
B.time(3600) 2 n# m0 W Y) B- R( b) n$ J6 N/ o AC.gmtime() + 3600+ z% Q' O' q; l
D.gmtime(3600)1 U+ ^4 D9 M u2 y
E.A和C都对 : ], Y; k) t$ n7 n # {4 A9 p g u6 F% h $ w) p0 W, I. u: R0 g/ m! O12.getdate()函数返回______。 0 u: F2 \; p1 K: T) [. t - e+ M; {6 g, p9 j% u* G) nA.一个整数 / w; g3 B n6 C q$ `+ h4 yB.一个浮点数/ @ _# {" @# c# y& u2 [
C.一个数组* X8 ]0 d4 R. m4 @9 l- Q' D' g2 O3 l
D.一个字符串; k! ~' p9 |0 A+ y: i9 m* j
E.一个布尔值 / I U" m" ?8 o 8 G5 h* `8 W: e0 I+ r, P ! e# _0 t A: ]4 a4 H5 Z! O13.要把microtime()的输出转化成一个数字值,以下那种方法最简便? s) F5 P- D+ K: k# |8 O: _9 { 2 X& w3 S4 j5 o" D6 EA.$time = implode (' ', microtime()); / j1 a3 | z+ h( b. L* i1 E- K# XB.$time = explode (' ', microtime()); $time = $time[0] + $time[1]; 1 \, a2 R- f q8 m2 zC.$time = microtime() + microtime();4 l B/ }" w" t) @( `6 o
D.$time = array_sum (explode (' ', microtime())); ' L( V+ d2 t9 KE.以上都不对5 t7 n3 Z# D! |; Y; C
. s- f: A: i& K; b0 O2 a- H& N, n6 k
' q9 ?+ _3 U c14.以下哪个函数返回的不是时间戳?(双选) 2 b/ {/ _- h1 w% t" A' T( U+ p9 t% H. I
A.time()' U1 R0 g$ B( c
B.date()3 }. y4 l& P% X4 I+ l3 a( {8 A$ b
C.strtotime() ; R) W/ [6 b% W: JD.localtime()3 Q, t2 @: \6 t% z( F' Z
E.gmmktime(); M, Z8 f1 R4 A
: f, D% A( `! d( ?% u
) T5 E/ t* G) H/ c+ o+ k8 W6 |0 k/ V
15.GMT时区下的时间戳与你所在时区下的时间戳的秒数差距有多大? ( ]( q& N }% \! m5 k% s0 B* N* J s3 }# [5 h0 g/ ?
A.取决于你所在时区与GMT时区的时间差 ; t; J+ q/ E8 v# w8 XB.没有差别. n) _" Q; z& m6 A
C.只当你也在GMT时区时才会相同 $ z- H3 C' J7 B! U8 t; T( gD.永远不会相同 + [7 y5 @1 M0 z/ z0 Z) tE.以上都不对 6 s; y7 Z0 y* f k2 z * V) A! L' Q$ z" J- ~3 X9 x8 o3 E3 R+ G
% G: E: \1 |* v; k& K" w9 v4 u; N
答案速查. T3 N7 `( s P8 k; `
1:C 0 Y" L6 s7 c" t. r2:strftime() " q ^" I$ A: ^' u/ R0 B3:D/ _. H0 H* B4 {6 J' ~0 l" p9 n
4:D ; Q$ u; M$ Q7 M4 U5:C 8 u+ m' E6 Y" R' q6 ~6:A8 i9 P2 [( r+ z" s+ p# x/ h
7:BCD " H0 ~8 b. K' K& @5 K& ]! e8:B' O2 D2 L7 [& |. {4 w
9:E' m' B1 |* A. a/ t) ?
10:C $ m) g3 p: Y, W7 ]2 w11:A 2 C- x& T2 V/ _5 _# P! Y12:C' A+ j3 R: q0 |) [8 N1 ~% @+ ~
13:D) ~' K8 y! U# T2 y4 L. q- s$ g* B
14:BD/ m+ O! B! V6 \, r" Z
15:B2 K2 Q$ ]9 ]4 Y( a& Q1 M! @ C
$ ]/ |$ r( F+ B. Q8 f+ l0 d 2 v s* S1 |! ^' [, y% c 8 s# g1 i6 h( m) H' q3 n, v. s6 C答案 3 y+ A. d: y/ o! r- p9 Z0 S2 W3 t " ~8 C% W: D4 C2 W; I& P1.本题实际上很容易回答。特别指出操作系统平台其实是为了迷惑你,事实上,无论是在Windows、Linux或其他类UNIX等使用旧版glibc的平台上,strtotime函数都不能识别UNIX纪元之前的日期(译者注:PHP5里修正了这个问题),因此脚本输出-1,答案是C。. _/ o5 B! Z: s7 m
6 S# B( t7 Q7 I& d7 C
2.正确答案是strftime()。date函数只能格式化输出英文表示的日期,而strftime()则能根据脚本中的地区设置(可以通过stlocale()来改变)来决定在输出中使用的语言。$ v/ w: Z0 r d: k3 T
7 s# j) _0 O! W& u+ K3.答案是D。脚本中两次调用microtime()都能够获得当前时间,然而只有第二次执行该函数的时间会被算进时间段中。同样,第一次调用array_sum()函数被算进时间段,而第二次不会,因为第二次array_sum()是在microtime()后执行的。 * Z" Q9 D$ @4 y# n1 q* D4 |% Q) w2 P4 s
4.checkdate函数能检查格里高利日期(Gregorian date)的合法性(这个函数有一些局限性,比如October 5-14, 1582,尽管日历上并没有这个日期,但函数仍然认为它合法)。这个脚本实质上是创建了一个随机日期并验证它的合法性,答案是D。 . |0 t1 A% M2 ?2 E' `1 U0 `; K+ C, @/ N
5.和第一题不同,本题中脚本执行的平台会影响结果。在Windows下,mktime函数不支持负值(UNIX纪元之前的时间),函数将返回-1(和一个警告)。正确答案是C。 / j w7 O9 e* @4 L1 j- i ( K& k. s5 W4 ?! A" w |6.由于两个时区有一小时的时差,而strtotime()能把文本表示的日期转换成时间戳,因此结果只能是3600或者-3600(答案A或者B,即一小时相当于的秒数)。现在,最重要的是紧记,CST比EST晚一个小时,也就是当CST是午夜12点时,EST已经是次日了。因此$b比$a大,结果是负数,答案是A。, T3 c! \" e: [1 ~+ E% P |4 s
% b, A" R2 ]) D2 Y( a
7.数据库存储日期/时间的能力比PHP强。大多数DBMS能够处理格里高利日历上所有的日期,而基于UNIX时间戳的PHP只能处理较短的一个时间段里的日期。因此在脚本中处理日期时,必须确保在它转换成时间戳后不会溢出(答案B)。此外,在处理日期时,无论是验证一个日期的合法性(答案C)还是进行计算(答案D),都最好尽量让数据库来完成。 4 n) N# X1 w4 W) \/ E' W( t4 o! L- G
8.这是个很迷惑人的问题,但其实很简单。传给gmmktime()的值其实就是UNIX纪元,转化成时间戳后是0。gmmktime()的内部用到mktime(),后者基于当前地区工作。这里的问题是,UNIX纪元不能被用在本初子午线以东的时区——比如莫斯科。这将产生一个负值,Windows操作系统不支持。因此脚本输出-1,答案是B。也可能会输出一个警告,取决于你的设置(但绝对不是答案D说的“一个错误”)。) R5 k4 O2 Z, A: b9 [& W) H
`. a3 F5 K7 n
9.答案是E。很显然,time()计算从UNIX纪元开始至今经过的秒数,答案A和D都表述了这一点,它们都是正确的。答案B和C说的不是那么直接,但其实也表达了相同的意思。UNIX纪元是一个确定的时间点,因此无论你使用GMT时区或其他你所在的时区,从UNIX纪元至今经过的秒数都是一样的。只有在你把时间戳转换成人们能够理解的表达形式时才需要考虑时区。所以答案B和C也是正确的。这题似乎有点戏弄人的意思,但实际上它考验你对绝对时间与相对时间二者不同之处的认识,这个概念在处理日期时相当重要。+ i0 @3 H$ c* ~* v
( a7 c7 W) t9 z
10.传递给date()的参数H和s代表24小时制的时间与秒数。i被一个反斜线转义,因此它将被当作字母直接输出。调用strtotime()时没有给出参数,它将返回当天午夜的时间。因此最终的输出是00:i:00,答案是C。 : \% C! k# j( D1 B) o9 M; i : x# W9 G, q& v11.正确答案是A,当前时间加3600秒(1小时*60分钟*60秒)。其他选项都会产生错误的时间戳。 ( E1 L9 f3 e- R& [5 Z; p* ^6 Q( N + B5 c0 E; m+ L12.getdate函数返回记录指定时间戳相关信息的数组(如果没有指定时间戳,就改用当前日期)。答案是C。6 e( t, u$ f% N+ c) T2 r% f" c. ?3 v0 G
9 B" a) |" i O: k+ r0 z3 ^13.答案是D。microtime函数返回一个由时间戳和小数两部分组成的字符串,两部分由空格分开。因此explode()将字符串分割并放入数组,array_sum()把它们相加,转换成数字。 $ s2 x, I" T: K" g+ Q) q. a8 d6 F' S3 o T. m! G0 p
14.答案是B和D。date函数返回字符串,localtime()返回数组。 . k0 `0 i( D. H. j! x* k# H/ q# v5 V& b+ K
15.任何时区下的当前时间都是相同的——当前时间是一个绝对的时间点。答案是B。