您好,登錄后才能下訂單哦!
數組指針怎么在PHP項目中使用?針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。
要使用數組中的元素,就需要數組的定位。定位的實現需要借助數組指針來完成。PHP中有很多函數可以移動數組指針。下面將給大家介紹幾個。
將指針移動到下一個數組位置next()
next()函數返回緊接著放在當前數組指針下一個位置的數組值。其形式如下:
mixed next(array array)
以下是一個例子:
$fruits = array("apple", "banana", "orange", "pear"); echo next($fruits); echo next($fruits); // banana // orange
還可以將指針前移,也可以直接移動到數組的開始和結尾位置。
將指針移動到前一個數組位置prev()
prev()函數返回位于當前指針前一個位置的數組值,如果指針本來就位于數組的第一個位置,則返回false。其形式如下:
mixed prev(array array)
prev()的用法與next()相同,例子就省略了。
將指針移到第一個數組位置reset()
reset()函數用于將數組指針設置回數組的開始位置。其形式如下:
mixed reset(array array)
如果需要在腳本中多次查看或處理一個數組,就經常使用這個函數,另外這個函數還經常在排序結束時使用。
將指針移動到最后一個數組位置end()
end()函數將指針移動到數組的最后一個位置,將返回最后一個元素。其形式如下:
mixed end(array array)
下面的例子展示了如果獲取第一個和最后一個數組值:
$fruits = array("apple", "banana", "orange", "pear"); echo current($fruits); echo end($fruits); // apple // pear
對于數組作為參數在函數間傳遞時又存在這樣一個規律:我們知道,函數調用時,系統會將實參copy一份賦值給形參(引用調用除外),而對于數組,不僅僅 copy了實參的值,而且還copy了實參數組當前內部指針的位置。如果實參內部指針的位置指向了數組末尾,那么系統會將形參的內部指針重置,指向形參數 組的第一個單元;如果實參內部指針的位置不在數組末尾,即指向了有效的單元,那么系統會將形參的數組指針位置與實參的數組指針指向值相同的數組單元。
如果不做 $arr['var6'] = 6 這一步操作,6個變量($var1-$var6)都將有值,因為在each之后,數組指針已經指向了數組的末尾,那么在調用函數 func()時,系統會重置 $arrtmp的數組指針,將其指向第一個元素。但是在進行 $arr['var6'] = 6這步操作之后,一切就改變了,這一個操作讓$arr的數組指針由原來指向一個NULL變成了一個有效值(說明一下,賦值前后,數組指針指向的地址單元一 直是沒有變化的,只不過是賦值前,那個地址單元什么也沒有,而賦值之后變成了6)。這就使得$arr的數組指針指向了一個有效的單元,那么在調用函數 func()時,系統是不會重置$arrtmp的數組指針的,$arrtmp的數組指針將會跟$arr的數組指針一樣,指向他自己的最后一個單元。而 each函數又是從當前數組指針的位置開始工作的。因此each函數操作的第一個結果的返回值就是數組$arrtmp的最后一個元素了,它將數組指針再向下移動一位,while循環到此結束,因此$arrtmp['var1']-$arrtmp['var5']都沒有被遍歷到,最終導致$var1-$var6為NULL。
數組在賦值的過程中,賦值數組和被賦值數組各自數組指針的變化情況。 先給出一條結論,然后我們在用代碼來證明這個結論吧。$arrtmp=$arr;在這個賦值表達式中我把$arr叫做賦值數組,把$arrtmp叫做被賦值數組。數 組在賦值時,如果賦值數組的數組指針已經指向了數組末尾,則賦值之后賦值數組的數組指針會被重置,指向數組第一個元素;如果在賦值時,賦值數組的數組指針 沒有指向數組末尾,而是指向了任何一個有效的數組元素,那么在賦值之后賦值數組的數組指針是不會被重置的,而是保留其原來指向的元素。在賦值之后,被賦值 數組不僅有了賦值數組的值,而且賦值數組的數組指針指向了那個元素,被賦值的數組也會指向自己中值相同的那個元素。
demo1:
<?php $arr = array('var1'=>1,'var2'=>2,'var3'=>3,'var4'=>4,'var5'=>5); while( list($key,$value) = each($arr) ) { if($value == 4) break; } var_dump(current($arr)); $arr1 = $arr; var_dump(current($arr)); var_dump(current($arr1)); ?>
demo1 的執行結果是:int(5) int(5) int(5) 。從這個結果可以看出,賦值前后$arr的數組指針位置沒有發生任何變化,$arr1不僅值跟$arr相同,而且數組指針所指向的元素值也是相同的。現在 用上述結論來解釋這個結果,在while循環中,有一個if判斷語句,目的是不讓$arr的數組指針指向數組末尾,而是保留在一個有效的位置。 在$value=4時會跳出循環,而each這個函數會將數組指針向前移動一位,這就導致了$arr的數組指針指向了第5個元素,所以在賦值之 前,current($arr)的結果是5,賦值之后,由于在賦值之前$arr的當前指針并沒有指向末尾,因此在賦值之后不會將$arr的數組指針進行重 置,而是保留了其原有的位置,因此在賦值之后使用current($arr)的結果仍然是5。賦值時$arr1不僅獲得了$arr的值,而且數組指針指向 的元素和$arr的相同,二者都是5。
<?php $arr = array('var1'=>1,'var2'=>2,'var3'=>3,'var4'=>4,'var5'=>5); while( list($key,$value) = each($arr) ) { //if($value == 4) break; } var_dump(current($arr)); $arr1 = $arr; var_dump(current($arr)); var_dump(current($arr1)); ?>
demo2中我們將 if($value == 4) break; 這一句注釋掉了,目的很簡單,就是通過each將$arr的數組指針位置指向數組末尾。
demo2 的執行結果:bool(false) int(1) bool(false) 。如果數組指針對應的元素為0,"",或者不是一個有效的值時,current函數會返回false,$arr的值中沒有為0或者""的情況,因此可以斷 定是因為數組指針指向了一個無效的元素而導致current返回了一個false。換句話說就是可以確定在while循環完成之后,$arr的數組指針已 經指向了數組的末尾。所以我們看到在賦值之前current($arr)的值是false,而賦值之后current($arr)的值變成了1,說明賦值 之后$arr的數組指針被重置了,指向了數組的第一個元素。current($arr1)的值為false,說明賦值之后$arr1讓然保留了賦值之 前$arr的數組指針指向的元素。
通過demo1和demo2就可以證明上述結論了。
因此為了在遍歷數組時不受數組指針的影響,最好在使用each()函數之前或者之后調用函數reset()將數組指針重置。這樣就可以避免上述問題的發生了。另外還有一個操作數組指針的函數prev(),它的作用是將數組指針當前的位置后退一位,它也需要注意一點,就是如果數組指針已經指向數組末尾,那么使它就得不到想要的結果了。
順便說一下foreach這個函數,使用foreach函數來遍歷數組時,它會重置數組指針,將其指向數組的第一個元素。必須注意的是foreach操作的對象是對你要遍歷的數組的copy值,而不是遍歷數組本身。
關于數組指針怎么在PHP項目中使用問題的解答就分享到這里了,希望以上內容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注億速云行業資訊頻道了解更多相關知識。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。