一个简单php扩展介绍与开发教程
前端之家收集整理的这篇文章主要介绍了
一个简单php扩展介绍与开发教程,
前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我们使用PHP扩展,主要目的是提高程序的执行效率,对于访问量很大的代码或者逻辑将其写成扩展。在做项目的过程中,需要对数据进行排序,数据运算比较复杂;我们准备对一百万个数据进行排序, 下面是我在程序之前做的一个测试:首先使用PHP程序生成一百万的随机数,并将其保存在文件中。
生成随即数的代码如下面所示:
<div class="codetitle"><a style="CURSOR: pointer" data="90671" class="copybut" id="copybut90671" onclick="doCopy('code90671')"> 代码如下:
<div class="codebody" id="code90671">
set_time_limit(0);
ini_set("memory_limit",-1);
$data = array();
for($i = 1; $i < 1000000; $i++)
$data[] = rand();
file_put_contents('data.
PHP','<?php $data = ' . var_export($data,true) . "; ?>");
代码很简单,一看就明白,这里不作说明。
下面是使用
PHP写的
快速排序,
PHP自身带的排序
函数,以及自己扩展的排序
函数,它们所需时间如下所示:
下面将
PHP代码展示一下,需要说明的是:hello
函数时自己写的扩展
<div class="codetitle">
<a style="CURSOR: pointer" data="82385" class="copybut" id="copybut82385" onclick="doCopy('code82385')"> 代码如下: <div class="codebody" id="code82385">
<?
PHP ini_set("memory_limit",-1);
set_time_limit(0);
include_once('data.
PHP'); //刚才产生的
随机数保存在这个
文件 $len = count($data);
$data_s = $data_q = $data;
$s_s = $s_t = array_sum(explode(" ",microtime()));
qsort($data,$len-1);
$s_t = array_sum(explode(" ",microtime()));
sort($data_s);
$q_t = array_sum(explode(" ",microtime()));
$data_q = hello($data_q);
$r_t = array_sum(explode(" ",microtime()));
echo "
PHP写的
快速排序时间: " . ($s_t-$s_s) . "
";
echo "系统排序
函数使用时间为: " . ($q_t-$s_t) . "
";
echo "本地排序
函数使用时间为: " . ($r_t-$q_t) . "
";
echo "两个结果的对比:" . ($data_s === $data_q);
function qsort(&$arr,$l,$u)
{
if($l >= $u)
return;
$m = $l;
for($i = $l+1; $i<=$u; $i++)
{
if($arr[$i] < $arr[$l])
{
$m++;
if($m != $i)
{
$t = $arr[$i];
$arr[$i] = $arr[$m];
$arr[$m] = $t;
}
}
}
$t = $arr[$l]; $arr[$l] = $arr[$m]; $arr[$m] = $t;
qsort($arr,$m-1);
qsort($arr,$m+1,$u);
}
?>