• list()的相关问题


    由php手册中可以看到对list的定义:

    list — 把数组中的值赋给一些变量,像 array() 一样,这不是真正的函数,而是语言结构list() 用一步操作给一组变量进行赋值。

    array list ( mixed $varname [, mixed $... ] )

    可以看到list()的返回值一个数组;

    (1)使用list交换两个变量的值:

    $a = 'sb';
    $b = 'you';
    list($a,$b) = array($b,$a);
    echo $a,$b

    (2)官方文档中的栗子

    <?php
    
    $info = array('coffee', 'brown', 'caffeine');
    
    // 列出所有变量
    list($drink, $color, $power) = $info;
    echo "$drink is $color and $power makes it special.
    ";
    
    // 列出他们的其中一个
    list($drink, , $power) = $info;
    echo "$drink has $power.
    ";
    
    // 或者让我们跳到仅第三个
    list( , , $power) = $info;
    echo "I need $power!
    ";
    
    // list() 不能对字符串起作用
    list($bar) = "abcde";
    var_dump($bar); // NULL
    ?>

    (3)list的嵌套

    <?php
    
    list($a, list($b, $c)) = array(1, array(2, 3));
    
    var_dump($a, $b, $c);
    
    ?>
    int(1)
    int(2)
    int(3)

    Warning

    list() 从最右边一个参数开始赋值。如果你用单纯的变量,不用担心这一点。 但是如果你用了具有索引的数组,通常你期望得到的结果和在 list() 中写的一样是从左到右的,但实际上不是。 它是以相反顺序赋值的。

    Warning

    在 list() 执行过程中修改数组(比如使用 list($a, $b) = $b)将会产生不可预知的结果。

    Note:

    list() 仅能用于数字索引的数组并假定数字索引从 0 开始。

     (4)list()与each()组合使用来遍历数组

    1,each()介绍

    array each ( array &$array )

    返回数组中当前的键/值对并将数组指针向前移动一步

    在执行 each() 之后,数组指针将停留在数组中的下一个单元或者当碰到数组结尾时停留在最后一个单元。如果要再用 each 遍历数组,必须使用 reset()

    返回值

    返回 array 数组中当前指针位置的键/值对并向前移动数组指针。键值对被返回为四个单元的数组,键名为01key和 value。单元 0 和 key 包含有数组单元的键名,1 和 value 包含有数据。

    如果内部指针越过了数组的末端,则 each() 返回 FALSE

    2,举个栗子

    <?php
    $fruit = array('a' => 'apple', 'b' => 'banana', 'c' => 'cranberry');
    
    reset($fruit);
    while (list($key, $val) = each($fruit)) {
        echo "$key => $val
    ";
    }
    ?>
    以上例程会输出:
    
    a => apple
    b => banana
    c => cranberry
    Caution
    因为将一个数组赋值给另一个数组时会重置原来的数组指针,因此在上边的例子中如果我们在循环内部将 $fruit 赋给了另一个变量的话将会导致无限循环。
  • 相关阅读:
    Golang之字符串格式化
    BZOJ 4513: [Sdoi2016]储能表 [数位DP !]
    BZOJ 3329: Xorequ [数位DP 矩阵乘法]
    BZOJ 1833: [ZJOI2010]count 数字计数 [数位DP]
    HDU2089 不要62 BZOJ1026: [SCOI2009]windy数 [数位DP]
    未完
    [Miller-Rabin & Pollard-rho]【学习笔记】
    BZOJ 3551: [ONTAK2010]Peaks加强版 [Kruskal重构树 dfs序 主席树]
    BZOJ 3123: [Sdoi2013]森林 [主席树启发式合并]
    BZOJ 3545: [ONTAK2010]Peaks [Splay启发式合并]
  • 原文地址:https://www.cnblogs.com/isykw/p/6268564.html
Copyright © 2020-2023  润新知