PHP數(shù)組游標實現(xiàn)對數(shù)組的各種操作詳解
本文實例分析了PHP數(shù)組游標實現(xiàn)對數(shù)組的各種操作。分享給大家供大家參考,具體如下:
如何不用foreach實現(xiàn)對數(shù)組實現(xiàn)循環(huán)?
答:我們只需要模擬foreach就行了,數(shù)組在執(zhí)行foreach循環(huán)的時候,是有一個游標指向當前數(shù)組循環(huán)到的值,
那如果我們能拿到這個游標,并且操作游標,使游標前進或者后退,那么我們就能不用foreach而實現(xiàn)循環(huán)數(shù)組
直接上代碼,清晰直觀:
<?php
$arr = array('你','若','安','好','便','是','晴','天');
//current()函數(shù)是取得游標所在數(shù)組位置的值
//next()是使游標向數(shù)組的尾部移動一格
for(;$v=current($arr);next($arr)){
echo $v,'<br />';
}
/*
返回
你
若
安
好
便
是
晴
天
*/
//那么又如何使游標2步2步一走呢?
for(;$v=current($arr);){
echo $v,'<br />';
next($arr);
next($arr);
}
//執(zhí)行結果,沒有反應,這是為什么呢?
//原因是前面一個循環(huán)游標已經(jīng)到了數(shù)組的最尾部了
//因此,當執(zhí)行current($arr)時總是返回false,
//因此第二個循環(huán)是不會執(zhí)行的
//因此這里我們會用一個reset()方法來使游標重新指向數(shù)組的頭部
reset($arr);
echo '<hr />';
for(;$v=current($arr);){
echo $v,'<br />';
next($arr);
next($arr);
}
//那么又如何走2步,退一步呢?
reset($arr);
echo '<hr />';
for($flag=true;$v=current($arr);){
echo $v,'<br />';
if($flag){
next($arr);
next($arr);
$flag=false;
}else{
prev($arr);
$flag=true;
}
}
/*
返回
你
安
若
好
安
便
好
是
便
晴
是
天
晴
*/
//如何倒著循環(huán)呢?
//這里要用到end()函數(shù)了,讓數(shù)組的游標指向尾部
end($arr);
echo '<hr />';
for(;$v=current($arr);prev($arr)){
echo $v,'<br />';
}
/*
返回:
天
晴
是
便
好
安
若
你
*/
//注意當數(shù)組的值等于0,false,null,undefined,""時,for循環(huán)的第二部會返回false,就會使循環(huán)終止
reset($arr);
echo '<hr />';
$arr2 = array('你','若',0,'好','便','是','晴','天');
for(;$v=current($arr2);next($arr2)){
echo $v,'<br />';
}
/*
返回
你
若
*/
?>
除了這些還可以用key()函數(shù)得到游標所指向的鍵。
更多關于PHP數(shù)組相關內容感興趣的讀者可查看本站專題:《PHP數(shù)組(Arrary)總結》
希望本文所述對大家PHP程序設計有所幫助。
相關文章
php實現(xiàn)無限級分類實現(xiàn)代碼(遞歸方法)
近期做的一個網(wǎng)站需要一個無限級下拉列表的無限級分級功能,于是就有了下面的作品。2011-01-01
PHP下通過exec獲得計算機的唯一標識[CPU,網(wǎng)卡 MAC地址]
PHP下通過exec獲得計算機的唯一標識的代碼,可獲得CPU,網(wǎng)卡 MAC地址信息。2011-06-06
php基礎知識:類與對象(3) 構造函數(shù)和析構函數(shù)
php基礎知識:類與對象(3) 構造函數(shù)和析構函數(shù)...2006-12-12

