浅谈PHP源码十:关于array_keys,array_values函数
内容导读
收集整理的这篇技术教程文章主要介绍了浅谈PHP源码十:关于array_keys,array_values函数,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2174字,纯文字阅读大概需要4分钟。
内容图文
这篇文章主要介绍了关于浅谈PHP源码十:关于array_keys,array_values函数,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下新年的第一篇文章,首先给各位朋友拜年
今天有空看了下代码,写点东西,留作纪念!
array array_keys ( array input [, mixed search_value [, bool strict]] )
array_keys() 返回 input 数组中的数字或者字符串的键名。
如果指定了可选参数 search_value,则只返回该值的键名。否则 input 数组中的所有键名都会被返回。自 PHP 5 起,可以用 strict 参数来进行全等比较(===)。
array_keys 函数的实现在standard/array.c文件的2416行 PHP_FUNCTION(array_keys)
程序依照PHP一贯的风格,先判断输入是否正确,如果有第三个参数,则判断大小的函数使用is_identical_function(默认情况下是使用 is_equal_function函数)
然后初始化返回的数组,遍历所给的数组,取每个元素的key值,赋值给返回的数组,这个key值又分为数字和字符串两种,其中最主要的函数是hash操作函数zend_hash_get_current_key_ex(取当前元素的key值)
ZEND_API int zend_hash_get_current_key_ex(HashTable *ht, char **str_index, uint *str_length, ulong *num_index, zend_bool duplicate, HashPosition *pos){ Bucket *p; p = pos ? (*pos) : ht->pInternalPointer; IS_CONSISTENT(ht); if (p) { if (p->nKeyLength) { // 数字型的nKeyLength长度为0 if (duplicate) { *str_index = estrndup(p->arKey, p->nKeyLength - 1); } else { *str_index = p->arKey; // /* arKey存储key名称(字符串类型的key)必须是最后一个成员,*/ } if (str_length) { *str_length = p->nKeyLength; } return HASH_KEY_IS_STRING; } else { *num_index = p->h; // 存储数字key值 return HASH_KEY_IS_LONG; } } return HASH_KEY_NON_EXISTANT;}
对于此函数的理解主要是对bucket定义的了解
与bucket相关的内容请移步http://www.gxlcms.com/php-weizijiaocheng-405316.html
array array_values ( array input )
array_values() 返回 input 数组中所有的值并给其建立数字索引。
array_values 函数与array_keys的函数实现基本类似,并且还少了一个zend_hash_get_current_key_ex操作和判断值类型的操作,
以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!
相关推荐:
浅谈PHP源码九:关于array_unshift, array_push的介绍
浅谈PHP源码八:关于array_pop, array_shift的介绍
浅谈PHP源码七:关于nl2br, ltrim, rtrim, trim函数
以上就是浅谈PHP源码十:关于array_keys,array_values函数的详细内容,更多请关注Gxl网其它相关文章!
内容总结
以上是为您收集整理的浅谈PHP源码十:关于array_keys,array_values函数全部内容,希望文章能够帮你解决浅谈PHP源码十:关于array_keys,array_values函数所遇到的程序开发问题。 如果觉得技术教程内容还不错,欢迎将网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。