您好,欢迎访问一九零五行业门户网

PHP中array_keys和array_unique函数源码的分析,arraykeys_PHP教程

php中array_keys和array_unique函数源码的分析,arraykeys性能分析
从运行性能上分析,看看下面的测试代码:
$test=array();for($run=0; $runnnumofelements nnumofelements + 1) * sizeof(struct bucketindex), z_arrval_p(array)->persistent); if (!artmp) { zval_dtor(return_value); return_false; } for (i = 0, p = z_arrval_p(array)->plisthead; p; i++, p = p->plistnext) { artmp[i].b = p; artmp[i].i = i; } artmp[i].b = null; // 排序 zend_qsort((void *) artmp, i, sizeof(struct bucketindex), php_array_data_compare tsrmls_cc); /* 遍历排序好的数组,然后删除重复的元素 */ lastkept = artmp; for (cmpdata = artmp + 1; cmpdata->b; cmpdata++) { if (php_array_data_compare(lastkept, cmpdata tsrmls_cc)) { lastkept = cmpdata; } else { if (lastkept->i > cmpdata->i) { p = lastkept->b; lastkept = cmpdata; } else { p = cmpdata->b; } if (p->nkeylength == 0) { zend_hash_index_del(z_arrval_p(return_value), p->h); } else { if (z_arrval_p(return_value) == &eg(symbol_table)) { zend_delete_global_variable(p->arkey, p->nkeylength - 1 tsrmls_cc); } else { zend_hash_quick_del(z_arrval_p(return_value), p->arkey, p->nkeylength, p->h); } } } } pefree(artmp, z_arrval_p(array)->persistent);}/* }}} */
可以看到,这个函数初始化一个新的数组,然后将值拷贝到新数组,然后在45行调用排序函数对数组进行排序,排序的算法是zend引擎的块树排序算法。接着遍历排序好的数组,删除重复的元素。整个函数开销最大的地方就在调用排序函数上,而快排的时间复杂度是o(nlogn),因此,该函数的时间复杂度是o(nlogn)。
结论
因为array_unique底层调用了快排算法,加大了函数运行的时间开销,导致整个函数的运行较慢。这就是为什么array_keys比array_unique函数更快的原因。
您可能感兴趣的文章:php下判断数组中是否存在相同的值array_uniquephp array_unique之后json_encode需要注意php数组函数序列之array_unique() - 去除数组中重复的元素值php数组函数序列之array_keys() - 获取数组键名php获取数组中某元素的位置及array_keys函数应用
http://www.bkjia.com/phpjc/1104337.htmlwww.bkjia.comtruehttp://www.bkjia.com/phpjc/1104337.htmltecharticlephp中array_keys和array_unique函数源码的分析,arraykeys 性能分析 从运行性能上分析,看看下面的测试代码: $test=array();for($run=0; $run10000; $run++)...
其它类似信息

推荐信息