数组是以连续方式存储数据的结构,可通过索引访问。 不要将它们与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