찾다
php教程PHP源码100%并发无误, PHP高效文本缓存类.

代码

<?php

$old = sprintf(&#39;%1.4f&#39;, memory_get_peak_usage() / 1024) .&#39; KB&#39;;

class caches{
    public  $keep_time = 3600;
    public  $file_path = &#39;./cache.txt&#39;;
    private $handle    = null;
    private $time      = 0;
    public function __construct(){
        $this->time = time();
    }
    
    public function read($key, $keep_time=0){
        # 取得第一行. 判断过期, 不存在, 异常情况, 影响返回值即可. 返回值决定write方法的调用.
        $keep_time === 0 && $keep_time = $this->keep_time;
        $list = $this->__get_one();
        
        # 是否更新判断.
            $check = true;
        if(!$list[$key])
            $check = false;
        if($check && (time() - $list[$key][&#39;t&#39;]) >= $keep_time)
             $check = false;
        
        # 取得第几行数据. 
        $line = $list[$key][&#39;l&#39;]+0;
        $i = 1;
        $data = &#39;&#39;;
        if($this->handle){
            while(!feof($this->handle)){
                if($i === $line){
                   $data = fgets($this->handle);
                }else{
                    // TODO: 有没有好办法跳过这步...
                   fgets($this->handle);
                }
                $i ++;
            }
        }
        
        # 无论如何都保障数据为数组返回.
        if($data){
            $data = $this->__data_parse($data,&#39;DECODE&#39;);
        }
        !$data && $data = array();
        return $data;
    }
    public function write($key, $val){
        # 取得第一行. 判断key是否已经存在了..
        $list = $this->__get_one();
        
        # 什么情况下可以写入.
        if($list[$key]){
            # 已经过期的情况下. write函数被调用后, 不管如何都当作过期.
            $list[$key][&#39;t&#39;] = $this->time;
            $list[&#39;end&#39;] = $list[$key][&#39;l&#39;];
        }else{
            $list[$key] = array(&#39;t&#39;=>$this->time,&#39;l&#39;=>($list[&#39;end&#39;]+1));
            $list[&#39;end&#39;] = $list[$key][&#39;l&#39;];
        }
        
        # 数据加密处理后再传给__write. $list[&#39;end&#39;] 表示更新哪一行. 
        return $this->__write($list[&#39;end&#39;], $this->__data_parse($val), serialize($list));
    }
    
    private function __get_one(){
        $this->__read_fopens();

        if(!$this->handle)
            return array();
        $list = array();
        if($seria = rtrim(fgets($this->handle))){
            $list = unserialize($seria);
            unset($seria);
        }
        
        !$list && $list = array();
        return $list;
    }
    
    private function __data_parse($data, $cls=&#39;ENCODE&#39;){
        # $State 参数以减少is_string, count两函数的调用.
        if($cls === &#39;ENCODE&#39;){
            # 一定要返回无换行的一行. 切记
            # gzcompress 非常占内存, 只是写入时执行.
            $data = base64_encode(gzcompress(serialize($data),9));
        }else{
            $data = unserialize(gzuncompress(base64_decode(rtrim($data))));
            if($State === false && count($data) === 1 && isset($data[0]) === true){
                $data = $data[0];
            }
        }
        return $data;
    }
    
    private function __write($line, $data, $firstline){
        $savedata = array();
        $line +=0;
        $i = 1;
        $savedata[0] = $firstline;
        if($this->handle){
            while(!feof($this->handle)){
                $savedata[$i] = rtrim(fgets($this->handle));
                if($i === $line){
                    $savedata[$i]= $data;
                }
                $i ++;
            }
        }
        
        if(!$savedata[$line])
            $savedata[$line] = $data;
        
        if($this->handle)
            $this->__closes();
            
        # 重新写入文件.
        if(!$fp = fopen($this->file_path, &#39;wb&#39;))
        if(!$fp = fopen($this->file_path, &#39;wb&#39;))
        if(!$fp = fopen($this->file_path, &#39;wb&#39;))
        if(!$fp = fopen($this->file_path, &#39;wb&#39;))
        if(!$fp = fopen($this->file_path, &#39;wb&#39;))
            return 0;
        
        flock($fp, LOCK_EX | LOCK_NB);
        $ints = 0;
        //$ints = fwrite($fp, implode(PHP_EOL, $savedata));
        foreach($savedata AS $key => $val){
            if($key === 0){
                $ints += fwrite($fp,$val);
            }else{
                $ints += fwrite($fp,PHP_EOL.$val);
            }
            if($key === 0 && $ints <= 0)
                break;
        }
        unset($savedata);
        flock($fp, LOCK_UN);
        fclose($fp);
        
        return $ints;
    }
    
    private function __read_fopens(){
        $cls = &#39;rb&#39;;
        if($this->handle)
            $this->__closes();
        if(is_file($this->file_path) === false)
            return false;
        
       if(!$this->handle = fopen($this->file_path,$cls))
       if(!$this->handle = fopen($this->file_path,$cls))
       if(!$this->handle = fopen($this->file_path,$cls))
       if(!$this->handle = fopen($this->file_path,$cls))
       if(!$this->handle = fopen($this->file_path,$cls))
            $this->handle = null;
       if($this->handle)
       flock($this->handle,LOCK_EX | LOCK_NB);
    }
    private function __closes(){
        if($this->handle){
            flock($this->handle, LOCK_UN);
            fclose($this->handle);
            $this->handle = null;
        }
    }
}

########################################### 调用代码 #########################################
set_time_limit(0);
$atime = microtime(true);
$obj = new caches();

$read = 1;  // (0 / 1) 写入或者读, 测试效果.
$size = 10000; // 10K
$arr = range(1,100);  // 首次要快得多, 200:1秒, 1000:11秒
foreach($arr AS $val){
    if($read == 0){
        // 写入测试.
        $ints = $obj->write(&#39;key&#39;.$val,array(&#39;key&#39;=>str_repeat(&#39;A&#39;,$size)));
        echo &#39;key&#39;.$val.&#39; write size: &#39;. ($ints / 1000).&#39; KB<br />&#39;;
    }else{
        // 读缓存测试.
        $ints = $obj->read(&#39;key&#39;.$val);
        echo &#39;key&#39;.$val.&#39; read size: &#39;. strlen($ints[&#39;key&#39;]) / 1000 .&#39; KB<br />&#39;;
    }
}


#################################### 以下代码为监控作用 ####################################
echo &#39;<br />执行时间: &#39;;
echo sprintf(&#39;%1.4f&#39;,microtime(true) - $atime).&#39; 秒&#39;;

echo &#39;<br><br><br><br><hr>内存监控: &#39;;
echo $new = sprintf(&#39;%1.4f&#39;, memory_get_peak_usage() / 1024) .&#39; KB&#39;;
echo &#39;<br><hr>原始内存: &#39;;
echo $old;
echo &#39;<br><hr>增加内存: &#39;;
echo sprintf(&#39;%1.4f&#39;,$new - $old) .&#39; KB&#39;;
exit();
?>
성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 Linux 새 버전

SublimeText3 Linux 새 버전

SublimeText3 Linux 최신 버전

WebStorm Mac 버전

WebStorm Mac 버전

유용한 JavaScript 개발 도구

MinGW - Windows용 미니멀리스트 GNU

MinGW - Windows용 미니멀리스트 GNU

이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

PhpStorm 맥 버전

PhpStorm 맥 버전

최신(2018.2.1) 전문 PHP 통합 개발 도구