Heim >Backend-Entwicklung >PHP-Tutorial >有关PHP数组递归遍历的一点理解

有关PHP数组递归遍历的一点理解

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOriginal
2016-07-25 09:04:51913Durchsuche
  1. /**
  2. desc:数组
  3. */
  4. $arr = array (
  5. "1" => 'test',
  6. '2' => 'me',
  7. array (
  8. "3" => "beij",
  9. "4" => "zz"
  10. ),
  11. "45",
  12. array (
  13. "5" => "5",
  14. "6" => "ewrwer",
  15. "7" => "ssss",
  16. array (
  17. "8" => "ssd",
  18. "9" => "bdex"
  19. ),
  20. "10",
  21. "11"
  22. )
  23. );
  24. ?>
复制代码

接下来,编写递归函数打印这个数组:

  1. /**
  2. desc:递归遍历数组
  3. link:bbs.it-home.org
  4. date:2013/2/22
  5. */
  6. function RecursiveArr($patten, $array) {
  7. foreach ( $array as $value ) {
  8. if (is_array ( $value )) {
  9. $patten = $patten . $patten;
  10. RecursiveArr ( $patten, $value );
  11. } else {
  12. echo "

    " . $patten . "【" . key ( $array ) . "】" . ": " . $value . "
    " . "

    ";
  13. next ( $array ); // 给key赋值后需要移动到下一个,key才会更新
  14. }
  15. }
  16. }
  17. ?>
复制代码

调用示例:

  1. RecursiveArr ( '-', $arr );
复制代码

出现下面图中的结果: arr1.jpg 从上面的运行结果图可以看出,发现有些键是重复的。 为了比对区别和联系,接下来再看段代码:

  1. /**
  2. desc:递归遍历数组
  3. link:bbs.it-home.org
  4. date:2013/2/22
  5. */
  6. function RecursiveArr($patten, $array) {
  7. foreach ( $array as $value ) {
  8. if (is_array ( $value )) {
  9. $patten = $patten . $patten;
  10. RecursiveArr ( $patten, $value );
  11. } else {
  12. echo "

    " . $patten . "【" . key ( $array ) . "】" . ": " . $value . "
    " . "

    ";
  13. }
  14. next ( $array ); // 给key赋值后需要移动到下一个,key才会更新
  15. }
  16. }
复制代码

如果我把之前的递归函数改成上面的code,运行结果图如下: arr2.jpg

从上面的两种结果图应该可以看出一些什么了吧,亲。

说明: 若把next()函数使用在foreach中的if-else代码段中,则不同层级的顺序是可以记录和遵循的; 但如果把next()函数使用在foreach中的if-else代码段外的话,则顺序就是不区分层级直接递增的。 因此,如果需要针对键值进行处理,则需要格外的注意此处的变化,否则可能会让你像子弹一样飞...哈!



Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn