专栏首页程序员的碎碎念php Array数组知识总结

php Array数组知识总结

PHP 中的数组实际上是一个有序映射。映射是一种把 values 关联到 keys 的类型。此类型在很多方面做了优化,因此可以把它当成真正的数组,或列表(向量),散列表(是映射的一种实现),字典,集合,栈,队列以及更多可能性。由于数组元素的值也可以是另一个数组,树形结构和多维数组也是允许的。

先来一个实例:

在这个简单的实例中,我们用array()来创建了一个$array的数组,里面的‘a’~‘f’为数组的key(键),‘1’~‘6’为value(数值),var_dump是打印这个数组。

在右边界面你就可以看到显示出来的数据,你可以用count($array)或者sizeof($array)来打印出当前数组的length;在往数组中添加值可以这样子:$array[]=7;然后默认‘7’的key为0,当然你也可以这样:$array['g']='7';

接下来列举一些array实用函数:is_array():检测变量是否为数组,类似的还有is_int();is_float();is_numeric();is_string()和is_integer();

例子:

array_count_values():统计数组中的所有值array array_count_values ( array $array )

array_count_values() 返回一个数组: 数组的键是 array 里单元的值; 数组的值是 array 单元的值出现的次数。

例子:

array_rand():从数组中随机取出一个或者多个单元

mixed array_rand ( array $array [, int $num = 1 ] )

从数组中取出一个或多个随机的单元,并返回随机条目的一个或多个键。 它使用了伪随机数产生算法,所以不适合密码学场景,

例子:

shuffle():打乱数组

bool shuffle ( array &$array )

本函数打乱(随机排列单元的顺序)一个数组。 它使用的是伪随机数产生器,并不适合密码学的场合

例子:

接着我们想来分享下自己最近写的代码(素数、水仙花数):

判断是否为素数

判断是否为水仙花数

最后那就是其他的一些函数了,有兴趣的可以看一下:

函数

描述

PHP

array()

创建数组。

3

array_change_key_case()

返回其键均为大写或小写的数组。

4

array_chunk()

把一个数组分割为新的数组块。

4

array_combine()

通过合并两个数组来创建一个新数组。

5

array_count_values()

用于统计数组中所有值出现的次数。

4

array_diff()

返回两个数组的差集数组。

4

array_diff_assoc()

比较键名和键值,并返回两个数组的差集数组。

4

array_diff_key()

比较键名,并返回两个数组的差集数组。

5

array_diff_uassoc()

通过用户提供的回调函数做索引检查来计算数组的差集。

5

array_diff_ukey()

用回调函数对键名比较计算数组的差集。

5

array_fill()

用给定的值填充数组。

4

array_filter()

用回调函数过滤数组中的元素。

4

array_flip()

交换数组中的键和值。

4

array_intersect()

计算数组的交集。

4

array_intersect_assoc()

比较键名和键值,并返回两个数组的交集数组。

4

array_intersect_key()

使用键名比较计算数组的交集。

5

array_intersect_uassoc()

带索引检查计算数组的交集,用回调函数比较索引。

5

array_intersect_ukey()

用回调函数比较键名来计算数组的交集。

5

array_key_exists()

检查给定的键名或索引是否存在于数组中。

4

array_keys()

返回数组中所有的键名。

4

array_map()

将回调函数作用到给定数组的单元上。

4

array_merge()

把一个或多个数组合并为一个数组。

4

array_merge_recursive()

递归地合并一个或多个数组。

4

array_multisort()

对多个数组或多维数组进行排序。

4

array_pad()

用值将数组填补到指定长度。

4

array_pop()

将数组最后一个单元弹出(出栈)。

4

array_product()

计算数组中所有值的乘积。

5

array_push()

将一个或多个单元(元素)压入数组的末尾(入栈)。

4

array_rand()

从数组中随机选出一个或多个元素,并返回。

4

array_reduce()

用回调函数迭代地将数组简化为单一的值。

4

array_reverse()

将原数组中的元素顺序翻转,创建新的数组并返回。

4

array_search()

在数组中搜索给定的值,如果成功则返回相应的键名。

4

array_shift()

删除数组中的第一个元素,并返回被删除元素的值。

4

array_slice()

在数组中根据条件取出一段值,并返回。

4

array_splice()

把数组中的一部分去掉并用其它值取代。

4

array_sum()

计算数组中所有值的和。

4

array_udiff()

用回调函数比较数据来计算数组的差集。

5

array_udiff_assoc()

带索引检查计算数组的差集,用回调函数比较数据。

5

array_udiff_uassoc()

带索引检查计算数组的差集,用回调函数比较数据和索引。

5

array_uintersect()

计算数组的交集,用回调函数比较数据。

5

array_uintersect_assoc()

带索引检查计算数组的交集,用回调函数比较数据。

5

array_uintersect_uassoc()

带索引检查计算数组的交集,用回调函数比较数据和索引。

5

array_unique()

删除数组中重复的值。

4

array_unshift()

在数组开头插入一个或多个元素。

4

array_values()

返回数组中所有的值。

4

array_walk()

对数组中的每个成员应用用户函数。

3

array_walk_recursive()

对数组中的每个成员递归地应用用户函数。

5

arsort()

对数组进行逆向排序并保持索引关系。

3

asort()

对数组进行排序并保持索引关系。

3

compact()

建立一个数组,包括变量名和它们的值。

4

count()

计算数组中的元素数目或对象中的属性个数。

3

current()

返回数组中的当前元素。

3

each()

返回数组中当前的键/值对并将数组指针向前移动一步。

3

end()

将数组的内部指针指向最后一个元素。

3

extract()

从数组中将变量导入到当前的符号表。

3

in_array()

检查数组中是否存在指定的值。

4

key()

从关联数组中取得键名。

3

krsort()

对数组按照键名逆向排序。

3

ksort()

对数组按照键名排序。

3

list()

把数组中的值赋给一些变量。

3

natcasesort()

用“自然排序”算法对数组进行不区分大小写字母的排序。

4

natsort()

用“自然排序”算法对数组排序。

4

next()

将数组中的内部指针向前移动一位。

3

pos()

current() 的别名。

3

prev()

将数组的内部指针倒回一位。

3

range()

建立一个包含指定范围的元素的数组。

3

reset()

将数组的内部指针指向第一个元素。

3

rsort()

对数组逆向排序。

3

shuffle()

把数组中的元素按随机顺序重新排列。

3

sizeof()

count() 的别名。

3

sort()

对数组排序。

3

uasort()

使用用户自定义的比较函数对数组中的值进行排序并保持索引关联。

3

uksort()

使用用户自定义的比较函数对数组中的键名进行排序。

3

usort()

使用用户自定义的比较函数对数组中的值进行排序。

3

本文分享自微信公众号 - 程序员的碎碎念(gh_53e607dd4782),作者:benny

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

原始发表时间:2017-09-30

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • php实现归并排序算法

    归并操作(merge),也叫归并算法,指的是将两个顺序序列合并成一个顺序序列的方法。 如 设有数列{6,202,100,301,38,8,1} 初始状态:6,2...

    benny
  • php实现快速排序算法

    每次排序的时候设置一个基准点,将小于等于基准点的数全部放到基准点的左边,将大于等于基准点的数全部放到基准点的右边。这样在每次交换的时候就不会像冒泡排序一样只能在...

    benny
  • php实现冒泡排序算法

    冒泡排序,时间复杂度哦、O(N^2) 冒泡排序的核心部分是双重嵌套循环。不难看出冒泡排序的时间复杂度是 O(N 2)。这是一个非常高的时间复杂度。冒泡排序早在 ...

    benny
  • 【算法入门】用Python手写五大经典排序算法,看完这篇终于懂了!

    算法作为程序员的必修课,是每位程序员必须掌握的基础。作为Python忠实爱好者,本篇将通过Python来手撕5大经典排序算法,结合例图剖析内部实现逻辑,对比每种...

    黄博的机器学习圈子
  • js算法初窥02(排序算法02-归并、快速以及堆排序)

    zaking
  • PHP 数组使用之道

    这个教程我将通过一些实用的实例和最佳实践的方式列举出 PHP 中常用的数组函数。每个 PHP 工程师都应该掌握它们的使用方法,以及如何通过组合使用来编写更精简且...

    柳公子
  • PHP编程

    2.可变参数:func_get_args()、func_num_args()、fund_get_arg(argument_number)

    硬核项目经理
  • Numpy 入门之创建数组

    格式:loadtxt(fname, dtype=<class 'float'>, comments='#', delimiter=None, converter...

    用户6021899
  • 【大厂面试题】笔试题明明已经AC了,为什么还是把我挂掉了?乔戈里告诉你为什么

    给定一个二维数组,其每一行从左到右递增排序,从上到下也是递增排序。给定一个数,判断这个数是否在该二维数组中。

    乔戈里
  • Numpy 之ufunc运算

    ufunc是universal function的缩写,它是一种能对数组的每个元素进行操作的函数。NumPy内置的许多ufunc函数都是在C语言级别实现的,因此...

    用户6021899

扫码关注云+社区

领取腾讯云代金券