SPL-数组

数组是以连续方式存储数据的结构,可通过索引访问。 不要将它们与PHP数组混淆:PHP数组实际上实现为有序哈希表。

SplFixedArray类提供了数组的主要功能。

SplFixedArray和PHP数组之间的主要区别

  • SplFixedArray是固定长度的标准(标准数组),并且只允许范围内的整数作为索引。 优点是它允许更快的阵列实现。
  • PHP数组实际上实现为有序哈希表(一组数据的集合)。

方法

__construct — 构造一个新的固定数组
count — 返回数组的大小
current — 返回当前数组条目
fromArray — 在SplFixedArray实例中导入PHP数组
getSize — 获取数组的大小
key — 返回当前数组索引
next — 移动到下一个条目
offsetExists — 返回请求的索引是否存在
offsetGet — 返回指定索引处的值
offsetSet — 在指定索引处设置新值
offsetUnset — 取消设置指定$ index的值
rewind — 回滚迭代器回到开始
setSize — 更改数组的大小
toArray — 从固定数组返回一个PHP数组
valid — 检查数组是否包含更多元素
__wakeup — 反序列化后重新初始化数组

示例1

<?php

/*
构造一个新的固定数组,指定长度为5
*/
$array = new SplFixedArray(5);

/*
为指定的索引赋值
*/
$array[1] = 2;
$array[4] = "foo";

/*
数据结构:
object(SplFixedArray)#1 (5) {
  [0]=>
  NULL
  [1]=>
  int(2)
  [2]=>
  NULL
  [3]=>
  NULL
  [4]=>
  string(3) "foo"
}
*/
var_dump($array);

/*
数组长度为5
*/
var_dump($array->count());

/*
将数组的大小增加到10
*/
$array->setSize(10);

/*
长度增加的数组,原始数据不会发生变化
object(SplFixedArray)#1 (10) {
  [0]=>
  NULL
  [1]=>
  int(2)
  [2]=>
  NULL
  [3]=>
  NULL
  [4]=>
  string(3) "foo"
  [5]=>
  NULL
  [6]=>
  NULL
  [7]=>
  NULL
  [8]=>
  NULL
  [9]=>
  NULL
}

*/
var_dump($array);

/*
为扩充长度后的数组赋值
*/
$array[9] = "asdf";


/*
将数组缩小到2的大小
将从索引开始处,保存两个长度
object(SplFixedArray)#1 (2) {
  [0]=>
  NULL
  [1]=>
  int(2)
}
*/
$array->setSize(2);



/*
以下行抛出一个RuntimeException:索引无效或超出范围
*/ 
try {
    $array["username"]="jack";
} catch(RuntimeException $re) {
    /*
    RuntimeException: Index invalid or out of range
    索引只能是整数
    */
    echo "RuntimeException: ".$re->getMessage()."\n"; 
}

try {
    $array[-1]="jack";
} catch(RuntimeException $re) {
    /*
    RuntimeException: Index invalid or out of range
    索引不合法
    */
    echo "RuntimeException: ".$re->getMessage()."\n";
}

try {
    $array[5]="jack";
} catch(RuntimeException $re) {
    /*
    RuntimeException: Index invalid or out of range
    索引超出数组长度
    */
    echo "RuntimeException: ".$re->getMessage()."\n";
}

/*
查看数组大小
getSize/count  
*/
echo $array->getSize();
?>

示例2

<?php

$data=[1 => 1, 0 => 2, 3 => 3];

$sfa = SplFixedArray::fromArray($data);

/*
object(SplFixedArray)#1 (4) {
  [0]=>
  int(2)
  [1]=>
  int(1)
  [2]=>
  NULL
  [3]=>
  int(3)
}
*/
var_dump($sfa);

$data=[1 => 1, 2 => 2, true => 3,5=>5];
$sfa = SplFixedArray::fromArray($data);

/*
1 true转化为1,索引为1的数据会被更改为3
2 默认保存原始索引,而且索引从0开始,数据不存在,则默认为NULL
object(SplFixedArray)#2 (6) {
  [0]=>
  NULL
  [1]=>
  int(3)
  [2]=>
  int(2)
  [3]=>
  NULL
  [4]=>
  NULL
  [5]=>
  int(5)
}
*/
var_dump($sfa);

$data=[1 => 1, 2 => 2, true => 3,5=>5];
$sfa = SplFixedArray::fromArray($data,false);

/*
1 尝试保存原始数组中使用的数字索引。默认为true;
2 如果不保存原始数字索引,那么会返回非NULL的数组

object(SplFixedArray)#1 (3) {
  [0]=>
  int(3)
  [1]=>
  int(2)
  [2]=>
  int(5)
}

*/
var_dump($sfa);


$data=[1 => 1, 'a' => 2, true => 3];
/*
索引必须是整数
Fatal error: Uncaught exception 'InvalidArgumentException' with message 'array must contain only positive integer keys'
*/
//$sfa = SplFixedArray::fromArray($data);

?>

从哈希表的结构去理解PHP数组的特性

  • 支持典型的key->value查询
  • 可以当做数组使用
  • 添加、删除节点是O(1)复杂度
  • key支持混合类型:同时存在关联数组合索引数组
  • Value支持混合类型:array (“string”,2332)
  • 支持线性遍历:如foreach

从哈希结构去理解PHP数组的特性
不一般的PHP数组
PHP哈希表结构的深入剖析

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容