先不说什么先看实例
#1 array_unshift() example
先不说什么先看实例
#1 array_unshift() example
<?php
function deleteFromArray(&$array, $deleteIt, $useOldKeys = FALSE)
{
$key = array_search($deleteIt,$array,TRUE);
if($key === FALSE)
return FALSE;
unset($array[$key]);
if(!$useOldKeys)
$array = array_values($array);
return TRUE;
}
?>
实例
<?php
$stack = array("orange", "banana", "apple", "raspberry");
$fruit = array_pop($stack);
print_r($stack);
?>
经过此操作后,$stack 将只有 3 个单元:
array_splice定义和用法
说明
array array_splice ( array &$input , int $offset [, int $length [, array $ replacement ]] )
array_splice() 把 input 数组中由 offset 和 length 指定的单元去掉,如果提供了 replacement 参数,则用 replacement 数组中的单元取代。返回一个包含有被移除单元的数组。注意 input 中的数字键名不被保留。
(PHP 4, PHP 5)
array_push — 将一个或多个单元压入数组的末尾(入栈)
<?php
header('Content-Type: text/html; charset=utf-8');
// 简单冒泡算法 0 1 2 3 4
$a = array(5,4,3,2,1); //5
echo "比较54321 <br /><hr />";
function mp($a){ //传值 要是数组
//i=1 i<5 i++
for($i=0;$i<count($a);$i++){
/* j=3 j<i j--
* 这里为什么要-2呢
* 因为数组是从0开始的 所以要-1
* 然后 一会要比较后一位 和倒数第二位 所以 要-2
* 当然 -1 也可以 只要把 $a[j+1]改成$a[j] 然后把$a[j] 改成$a[j-1] 即可
*/
for ($j=count($a)-2;$j>=$i;$j--){
//判断数组最大的位数 和第二大的相比
if ($a[$j+1]<$a[$j]){
echo $a[$j+1],'------小于-----',$a[$j],'----------排列前:',fn($a);
//如果最大的小于第二大的就换位置
$tmp = $a[$j+1];
$a[$j+1]=$a[$j];
$a[$j]=$tmp;
echo '------------排列后:',fn($a),'<br><hr>';
}
}
}
return $a;
}
如
$array = file('phprm.com.txt');
按指定元素值去除数组元素
<?php//去除值为"Cat"的元素
$a=array("a"=>"Dog","b"=>"Cat","c"=>"Horse");
print_r($a);
unset($a[array_search("Cat",$a)]);
//array_search("Cat",$a)按元素值返回键名。去除后保持索引
print_r($a);
?>
<?php
$a=array("a"=>"Cat","b"=>"Dog","c"=>"Cat");
print_r(array_unique($a));
?>
例子1
代码如下:
<?php
$a=array(0=>"5",1=>"15",2=>"25");
echo array_sum($a);
?>
然而今天我却发现这个__autoload魔术方法或者你愿意称他为魔术函数,太专一了。当他加载需要包含的类文件时,甚至不管类文件中定义类之外的其它声明。
这个条件果然是成立的,按照我的思考逻辑上边的那个条件只有在参数1的值为”1,2,3“和为4的时候才成立,但是奇怪的是他居然成立了。战地随即测试了如下情况: