当前位置:Gxlcms > PHP教程 > strlen()完全不用php内部函数如何实现?

strlen()完全不用php内部函数如何实现?

时间:2021-07-01 10:21:17 帮助过:7人阅读

strlen()完全不用php内部函数如何实现?

回复内容:

strlen()完全不用php内部函数如何实现?

function mystrlen($str){
   $i = 0;
   while(1)if(!isset($str[$i++]))return $i-1;
}

效率不高,可以改进下,例如使用二分法用isset找到最大的坐标

改成這樣效率更高了一點

function mystrlen($str){
   $i = -1;
   while(1) if(!isset($str[++$i])) return $i;
}

function mystrlen($str){
   $size = 1024;//每次试探1024的范围
   $count = 0;//试探并且满足长度的次数
   $length = $size * $count - 1;//当前可以确定字符串具有的长度
   while( isset( $str[ $length + $size ] ) ){//依次试探1023,2047,3071,4095……
      $count = $count + 1;
      $length = $length + $size;
   }
   $low = 0;//二分查找下边界
   $high = $size - 1;//二分查找上边界
   while($low <= $high) {
     $mid = floor(($low + $high) / 2);
     if( isset( $str[$length + $mid] ) && !isset( $str[$length + $mid + 1] )){
        return $length + $mid + 1;
     }
     if( !isset( $str[$length + $mid] )){
       $high = $mid - 1;
     }
     if( isset( $str[$length + $mid] )){
       $low = $mid + 1;
     }
  }
}

//上面其它的答案里的方法,一个2M的字符串要循环200万次,简直了。
//我这种不是最佳方案,不过也将2M的字符串的循环减少到了2000多次。
//PHP保存字符串的时候本来就保存有长度,根本不用这么费事,用原生的函数轻松就能取出来,何必。

人气教程排行