返回列表 发帖

[Zend权威认证试题讲解]第四章 - 数组

PHP最强大的功能大概就是处理数组了。PHP允许开发者创建由各种不同数据类型的键和值组成的数组,并允许你对它进行排序、分割和组合等多种操作。$ c: C' X% |# q& h. t- F
力量越大,责任越大。找到最佳的办法来处理如此复杂的数组并不是一件轻松的事。本章一方面考察你对数组工作机制的认识——不光是理论上的,还要求实践。另一方面考察你“人工处理”简单脚本——指出哪里出错或者脚本将输出什么的能力。
0 ]3 m+ k2 G) M% Q0 U& w$ I
; K* Q0 w, `" d& e7 d6 n7 y
  G- ]4 S9 s7 i% `问题
) ?5 t* y) Y9 L" @. u2 i+ k8 q, F* k1 }$ s- p' ^1 T* G2 T: [
1.索引数组的键是______,关联数组的键是______。1 T/ x- a6 l: A8 Q3 {

! Y) [4 J0 P5 Q8 tA.浮点,字符串' K. F2 Y+ g9 x- i
B.正数,负数8 m3 E$ h1 [+ o1 F
C.偶数,字符串
2 N1 H/ Q9 K* W0 x- D0 o1 x8 w0 o; `D.字符串,布尔值' U4 A  V  h9 d$ T) |
E.整型,字符串
5 q- M+ o0 O9 d, U- v
3 R% k$ K% c8 [3 ~! \9 d
5 ~% z4 j/ p+ N. n2.考虑如下数组,怎样才能从数组$multi_array中找出值cat?

  1. <?php
  2. $multi_array = array("red",
  3. "green",
  4. 42 => "blue",
  5. "yellow" => array("apple",9 => "pear","banana",
  6. "orange" => array("dog","cat","iguana")));
  7. ?>
复制代码
A.$multi_array['yellow']['apple'][0]
: g. D. P6 i6 n0 L; ~3 lB.$multi_array['blue'][0]['orange'][1]' s4 N# v! p9 O5 Y& }/ h- e
C.$multi_array[3][3][2]& m% |2 T1 A6 Y4 ?. s! c; I. E
D.$multi_array['yellow']['orange']['cat']
) b7 c7 O7 [4 r3 ~3 T- fE.$multi_array['yellow']['orange'][1]% Z: x1 O, p! o2 }# K# j9 `

) T4 T# Y6 v2 T5 y* K
; S' h  k6 O8 f8 K' R3.运行以下脚本后,数组$array的内容是什么?

  1. <?php
  2. $array = array ('1', '1');
  3. foreach ($array as $k => $v) {
  4.         $v = 2;
  5. }
  6. ?>
复制代码
A.array ('2', '2')
4 _# P' `8 h+ G8 {3 R4 R: q; yB.array ('1', '1')4 B" T% S, e5 p0 f1 L$ ?6 W0 E
C.array (2, 2)7 Z/ P- ]" v% L, ]1 a
D.array (Null, Null), _* b; P4 w; _; S4 j. ^5 i  u) ?
E.array (1, 1)3 z8 ?5 h, G) A
8 ~# n0 ^# r7 b4 v$ ~) u0 T& E5 D

2 Q5 U: R2 e/ [: |# ~4.对数组进行升序排序并保留索引关系,应该用哪个函数?: p8 X( j6 u6 O0 g
; R7 R  G- z/ l8 K; s
A.ksort()3 \9 W- X" h+ q9 i
B.asort()
# U2 g, _) j: V" r- }C.krsort()
+ W/ P6 V  ~) B$ u7 ?0 \D.sort()
& N* d" Q8 V" G( CE.usort()
- W, Z' w' m$ J& _" \* ]4 u7 I+ F: L$ v  ^' y

# G+ M) `3 \# ~3 N5.哪个函数能把数组转化能字符串?
+ ?0 A0 z- d4 M' s. @5 m  ~
- w1 L3 ?% m7 [4 Y) E答案:____________
) k+ O; ~/ d7 l/ h7 y1 d* S* K4 h
5 o# \$ T( e* V
6.以下脚本将按什么顺序输出数组$array内的元素?

  1. <?php
  2. $array = array ('a1', 'a3', 'a5', 'a10', 'a20');
  3. natsort ($array);
  4. var_dump ($array);
  5. ?>
复制代码
A.a1, a3, a5, a10, a203 n; W1 m+ @5 J& M% I; C6 N) w
B.a1, a20, a3, a5, a10+ _- w8 e: q- a! o) S8 s
C.a10, a1, a20, a3, a5
5 a' @9 K! _3 c8 tD.a1, a10, a5, a20, a3
/ `4 k* L+ H) h. F4 ]' NE.a1, a10, a20, a3, a5& L, I9 {4 G) ?' y) g
; n, l9 n; i$ n

, q- `# Z$ [8 o! h1 [- i* e7.哪个函数能把下方数组的内容倒序排列(即排列为:array('d', 'c', 'b', 'a'))?(双选)

  1. <?php
  2. $array = array ('a', 'b', 'c', 'd');
  3. ?>
复制代码
A.array_flip()
1 y9 K* D' E  ~B.array_reverse()- S6 i& ]. f+ f5 k9 \1 e0 p
C.sort()% e# t2 v/ X4 D1 H$ g' b4 o0 Q
D.rsort()# Z0 }  S( k" r
E.以上都不对- p. _5 ~. K2 e
% z% L: t8 B: L/ p$ [

1 r& P8 g  n5 c; E' B3 j8.以下脚本输出什么?

  1. <?php
  2. $array = array ('3' => 'a', '1b' => 'b', 'c', 'd');
  3. echo ($array[1]);
  4. ?>
复制代码
A.1
4 w8 S3 f0 }$ A* h( HB.b
: [$ O9 D5 b! k: a9 u5 ~C.c
: k. ?9 H5 S4 o2 ED.一个警告& `4 H! h" i: ~$ y
E.a3 u0 m, L5 Z6 d+ P- H% A3 D* U

5 N7 O# s4 w. _. Z; E; S
4 b* E& b/ b+ {( I( d) ~9 ]: O( y9.哪种方法用来计算数组所有元素的总和最简便?
4 i1 A1 t) K1 y! B) `) U% D! m4 z- f, G1 N: X7 X$ F
A.用for循环遍历数组
6 H. |  m: d6 Y& P. N, mB.用foreach循环遍历数组
+ s2 x8 F2 O2 B$ O9 Q8 a* _C.用array_intersect函数' g' G/ u# M0 V4 ^/ j
D.用array_sum函数5 s% p. X8 c1 J* P+ o
E.用array_count_values()
6 b: G  w2 O" o' k" n" c; Q! Z0 J0 n+ Z, f
$ u4 B8 x2 J( d5 h
10.以下脚本输出什么?

  1. <?php
  2. $array = array (0.1 => 'a', 0.2 => 'b');
  3. echo count ($array);
  4. ?>
复制代码
A.1
% s) l: `$ D% }8 d8 TB.22 }$ C5 I. e" K) s
C.0  R$ ?& @; o7 ^6 i% Z
D.什么都没有
& |7 _5 p( @! c8 AE.0.3) t" a8 g/ N5 ?6 l4 @$ n

- Q; j* A6 C1 ~% Y% q
+ }# l! Z; C: Y0 K( \+ V" w2 t# s7 ~! Q11.以下脚本输出什么?

  1. <?php
  2. $array = array (true => 'a', 1 => 'b');
  3. var_dump ($aray);
  4. ?>
复制代码
A.1 => 'b'* _! D# v/ q. X+ b1 {0 G% x6 m6 o
B.True => 'a', 1 => 'b'
9 `5 L" w9 z* R6 x2 X! B: X4 x2 PC.0 => 'a', 1 => 'b'+ ?- i4 L1 q+ A( n# B
D.什么都没有
! s) f/ l9 e4 q4 S# L: K' L; WE.输出NULL
; H) Q9 K7 @  @( j' ]) [
5 j* P% l" y: Y4 k9 w; _# H) c( L% @  |- x0 ~$ V8 ~8 {, q* u
12.在不考虑实际用途的前提下,把数组直接传给一个只读函数比通过引用传递的复杂度低?9 b( g5 w" g; N4 z4 ~" h

1 D! ^* x5 P% e9 m5 X5 lA.是的,因为在把它传递给函数时,解释器需要复制这个数组* _) _. }# C# w+ s' Z0 ?6 R  w
B.是的,如果函数修改数组的内容的话2 k; Z) P1 k; I/ j6 h; V3 w) _
C.是的,如果这个数组很大的话
0 L' H3 d& m0 d7 l! FD.是的,因为PHP需要监视函数的输出,已确定数组是否被改变. z$ U0 ]+ }+ p1 w( ^  |
E.不是
9 c# X2 d" q) [( l( B+ e9 ~: g6 ^: I/ t
8 U& l  Z1 M! G! V8 {- `
12.以下脚本输出什么?

  1. <?php
  2. function sort_my_array ($array)
  3. {
  4.         return sort ($array);
  5. }
  6. $a1 = array (3, 2, 1);
  7. var_dump (sort_my_array (&$a1));
  8. ?>
复制代码
A.NULL
. i8 U" T% K3 S  s$ z5 jB.0 => 1, 1 => 2, 2 => 3
! s# }, q5 U2 z. W0 JC.一个引用错误
+ r. N5 R8 @. KD.2 => 1, 1 => 2, 0 => 3- f3 V, t% Z' d) D+ C# ^) s9 R/ E
E.bool(true)
4 s4 B" i! U; ~1 H9 V1 `1 ^  l# G/ F9 v" T' K* l
5 ]8 d6 l( v' Z# S  O
13.以下脚本输出什么?

  1. <?php
  2. $result = '';
  3. function glue ($val)
  4. {
  5.         global $result;
  6.         $result .= $val;
  7. }
  8. $array = array ('a', 'b', 'c', 'd');
  9. array_walk ($array, 'glue');
  10. echo $result;
  11. ?>
复制代码
答案:____________2 [0 T& q6 }7 c$ v* A

7 c* n: H& w' ?( L; P' B- I0 q+ I. Y
15.以下脚本输出什么?

  1. <?php
  2. $array = array (1, 2, 3, 5, 8, 13, 21, 34, 55);
  3. $sum = 0;
  4. for ($i = 0; $i < 5; $i++) {
  5. $sum += $array[$array[$i]];
  6. }
  7. echo $sum;
  8. ?>
复制代码
A.78" \, N, z/ u/ y$ T- ?& O4 a+ z
B.19. y* |7 E/ ~' q; V, D" b
C.NULL
4 R" y4 L5 F, z: }2 _+ H3 n8 e9 zD.5
. i# a7 L( _, ?5 n! p. e! ZE.0& q+ w6 R% f  }5 W$ I

1 U, c, T' F) R! [- b9 ]9 y
( ]- ?! x& R2 w: a- ^: n# M/ \  E1 y
答案速查
9 _- z2 P3 K4 }" e$ {1:E/ ~  f$ T2 {8 d3 {+ M
2:E) o* f* J0 p7 q% o; y
3:B2 R8 l" X, A/ W# s) _
4:B
4 s" _. s% |5 e  `; X5:serialize/implode5 c4 O8 Z* p4 r! X1 n
6:A
: ?6 v) H. M% R, A8 s4 r7:BD8 M' g6 x& b  }3 m6 B0 U
8:D
; g. F; B! n8 d8 W- h9 e9:D
4 l" ~0 i& T) b10:A
; a5 ?$ k8 p$ [" g11:E: F" [- X  _* N4 v( L/ o1 @/ t
12:E
* o0 b* \4 f6 r, y# \9 E& w1 ]13:E. k6 Q3 d% ?* L8 \
14:abcd
  C& h# K. E7 O' B! O, w* V1 |15:A
: h- X$ c6 R5 w  \& B" Y7 u
, Q. [' ~9 Y- `" A
* y- m0 K  L" f  I0 N+ X5 V
" v9 O5 z7 W4 O答案详解7 i( \: u8 i8 v8 b3 ?
- x2 @* O" Z6 m3 a# m
1.键名是整型数字(integer)的数组叫索引数组,键名是字符串的数组叫关联数组。正确答案是E。
4 R# k! `( Y- }& ?; `# H. y
& J2 j$ H7 `0 |( C/ \+ Z& Y2.cat被包含在另外两个数组中。顺藤摸瓜,首先,键yellow必须要用到,它跟在orange后面。最内部的数组是个索引数组,字符串cat是第二个值,它的索引是1。正确答案是E。$ ~4 g. q; b% ^: G6 S+ p

" y& m- y8 e, v" w/ f6 W2 o/ b3.答案是B。foreach操作的是$array的副本,因此对原来的值没有影响。& X" W0 n: X  e9 q) i

6 y" |) S. A$ ]  k! s# j( K4.只有asort函数能在保留原有索引关系的前提下进行排序。答案是B。
& G' @" |9 g; k* Y: \% \, P
- x6 t2 d& Y! V$ s# T5 A& D5.serialize函数能把复杂的数据结构转换成字符串,并可以用unserialize函数再转换回原先的结构。还有implode函数,它可以把数组中的所有元素组成一个字符串。
, `- ^6 h# I; B
2 ^. D+ L& w5 j6.函数natsort()使用“自然排序”法对数组进行排序。在本题中,数组元素已经“自然”排列了,因此函数根本没有改变数组。答案是A。; [+ ]% J. d/ O6 G. R; `  l* w

3 Y* I( t$ A3 o% B" v7.array_flip()只能把数组中每个元素的键和值进行交换。rsort()和array_reverse()则能把题目中的数组逆向排序为需要的形式(’d’,’c’,’b’,’a’)。答案是B和D。9 n0 Y! z2 {+ Y: S6 E
; H$ W4 G& e1 A% D
8.给数组中的元素设置数字键时,PHP从可用的最小的数字开始,递增设置。如果没有指定从哪个数字开始,PHP将从0开始。本题中,3是第一个元素的键,因此,第三个元素的键将被设置为4,最后一个元素是5。注意,1b不是数字。因此,键是1的值不存在,答案是D。
  p. j0 h" H' l2 Q) v; s. I7 s1 N1 s, I$ x
9.array_sum函数计算数组中所有元素的总和。答案是D。8 c; U% G6 `$ K( y5 M9 c# W
  _  {$ X& i0 b9 a
10.脚本输出1(答案是A)。因为只有整型数字和字符串可以被用来做数组的键——浮点数字会被转换成整型数字。所以0.1和0.2会被转换成0,$array中只有0=>’b’这个元素。
  D1 c+ W/ P0 U; S' p
( M( W6 A8 A: Z9 V( ^8 z5 M8 `11.这题试图把你的注意力从真正的问题上转移开。true等同于数字1,因此$array数组将只包含一个元素。然而在var_dump()函数里出现了一个错误——$array被错拼成了$aray,少了一个“r”。因此var_dump将输出NULL(也可能是一个提示 ,这取决于你的设置)。答案是E。
1 F% ~" G  X  v4 h4 W2 Y5 r, @9 `$ J7 ^9 f; B7 E: X9 Z
12.这题有些绕人。首先,注意两点:第一,你并非一定要使用这两种方式来传递数组。如果需要用一个函数来修改数组的内容,通过引用传递将是唯一的方法——但题中不是这种情况;第二,题目强调把数组传递个一个只读函数。如果不是这样,由于对数组进行改变将产生一个该数组的副本,答案会是B。然而常规情况下,PHP需要创建一套结构来维持一个引用,另一方面,由于PHP采用懒拷贝(lazy-copy)——又叫写时拷贝(copy-on-write)——机制,变量在被改变之前不会产生副本,所以通过引用将数组传递给一个不修改数组内容的函数比通过值传递要慢,而通过值传递是一种快速、安全的在函数间共用数组的方式。答案是E。3 e" Y6 J6 B+ m1 ^( u% @; Z
5 L3 Q8 }* H& ~9 b8 J) J& e
13.答案是E。sort函数不产生或返回数组副本,而是直接对传递给它的数组本体进行操作。该函数只返回布尔值true,代表排序成功(或者false,代表出错)。注意,这里将数组$a1引用传递给了sort_my_array(),我们不赞成这样做,应该在函数中重新声明引用。
3 \' Z# p: ]' [4 Q3 X, w: _" m0 J, D9 e. @+ w
14.array_walk函数将一个指定函数应用在数组中的每个元素上。因此脚本glue函数将把数组中的所有元素连在一起,输出abcd。4 B# ^. d' l# I( q$ U7 q
( i% c7 i) D3 A1 B7 X
15.本题主要考验你分析脚本的能力。你也许觉得这题很费解——但我们在调试别人写的代码时却不得不经常面对此类令人不悦的问题。相对于我们所见过的一些代码,这已经算相当简单了。脚本中的for循环了5次,每次都把键是数组$array中键为$i的值的值加进$sum。这听起来有点像绕口令,但如果你一步一步想,你将发现, 当$i等于零时,$array[$array[$i]]等同于$array[$array[0]],也就是$array[1],也就是2。顺着这个思路,最终的答案是78。

返回列表
【捌玖网络】已经运行: