PHP SPL, 잃 어 버 린 보석

표준 PHP 라 이브 러 리 (SPL): http://www.rafaeldohms.com.br/2009/06/03/spl-a-hidden-gem/en/
http://cn.php.net/spl PHP 5.0 부터 내 장 된 구성 요소 와 인터페이스 이 며, PHP 5.3 에서 점점 성숙 해 졌 습 니 다.SPL 은 사실 모든 PHP 5 개발 환경 에 내장 되 어 있 으 며 어떠한 설정 도 필요 하지 않 습 니 다.
많은 PHP 개발 자 들 이 그것 을 거의 사용 하지 않 았 고 심지어 들 어 본 적 이 없 는 것 같다.그 원인 을 따 져 보면, 그것 의 양춘 백설 같은 설명 문 서 를 추론 하여, 너 로 하여 금 그것 의 존 재 를 소홀히 하 게 할 수 있다.
SPL 이라는 보석 은 철 다 니 의 '바다의 마음' 처럼 바다 밑 으로 가 라 앉 았 다.지금 은 우리 에 게 건 져 내 고 그 위 치 를 차지 해 야 한 다 는 것 도 이 글 이 표현 하고 자 하 는 관점 이다.
그렇다면 SPL 은 무엇 을 제공 합 니까?
SPL 은 Array Access, Countable, Seekable Iterator 등 PHP 엔진 을 확장 하여 배열 형식 으로 대상 을 조작 하 는 데 사용 합 니 다.또한 RecursiveIterator, Array Obejcts 등 다른 교체 기 를 사용 하여 데이터 교체 작업 을 할 수 있다.
Exceptions, SplObserver, Spltorage 및 spl 와 같은 몇 개의 대상 도 내장 되 어 있 습 니 다.autoload_register、spl_classes、iterator_apply 등의 도움말 함수 (helper functions) 는 대응 하 는 기능 을 다시 불 러 오 는 데 사 용 됩 니 다.
이 도구 들 을 한데 모 으 는 것 은 다기 능 스위스 군 도 를 잘 사용 하면 질 적 으로 PHP 의 코드 효율 을 높 일 수 있다.그렇다면 우 리 는 어떻게 그 위력 을 발휘 할 것 인가?
자동 로 더 를 다시 불 러 옵 니 다.
만약 당신 이 '교과서 적 프로그래머' 라면 어떻게 사용 하 는 지 알 아 보 겠 습 니 다autoload 는 includes / equires 작업 타성 대신 대응 하 는 클래스 를 불 러 옵 니 다. 그 렇 죠?
그러나 오 랜 시간 동안 당신 은 이미 곤경 에 빠 졌 다 는 것 을 알 게 될 것 입 니 다. 먼저 당신 의 클래스 파일 이 지정 한 파일 경로 에 있어 야 한 다 는 것 을 보증 해 야 합 니 다. 예 를 들 어 Zend 프레임 워 크 에서 '' 를 사용 하여 클래스, 방법 이름 을 나 누 어야 합 니 다. (이 문 제 를 어떻게 해결 하 시 겠 습 니까?)
또 다른 문 제 는 프로젝트 가 점점 복잡 해 지면 서autoload 내의 논리 도 상응 하 게 복잡 해 질 것 이다.마지막 으로 이상 판단 을 넣 고 불 러 오 는 모든 논 리 를 그대로 기록 할 수도 있다.
다 들 아시 다시 피 "계란 은 한 바구니 에 넣 으 면 안 돼 요". SPL 로 분리 할 수 있어 요autoload 의 불 러 오기 논리.당신 의 autoload 함 수 를 쓰 고 SPL 에서 제공 하 는 함 수 를 이용 하여 다시 불 러 오기 만 하면 됩 니 다.
예 를 들 어 상기 Zend 프레임 워 크 의 문 제 는 Zend loader 에 대응 하 는 방법 을 다시 불 러 올 수 있 습 니 다. 해당 하 는 클래스 를 찾 지 못 하면 이전에 정 의 된 함 수 를 사용 하 십시오.
<?php
class MyLoader {
    public static function doAutoload($class) {
        //        autoload   
    }
}

spl_autoload_register( array('MyLoader', 'doAutoload') );

보시 다시 피 SPL, PHP 표준 라 이브 러 리 (표준 PHP 라 이브 러 리) 여러 개의 불 러 오기 논 리 를 배열 로 추가 할 수 있 습 니 다.또한 spl_autoload_register 더 이상 필요 하지 않 은 불 러 오 는 논 리 를 제거 할 수 있 습 니 다. 이 기능 은 항상 사용 할 수 있 습 니 다.
교체 기
교 체 는 흔히 볼 수 있 는 디자인 모델 중 하나 로 한 그룹의 데이터 에 보편적으로 응용 되 는 통 일 된 반복 작업 이다.SPL 은 데이터 형식 에 대응 하 는 모든 교체 기 를 제공 했다 고 해도 과언 이 아니다.
목록 을 옮 겨 다 니 는 아주 좋 은 사례 가 있 습 니 다.일반적인 방법 은 scandir 를 사용 한 다음 "........................................................................................
다음 코드 는 SPL 의 교체 기 를 사용 하여 지정 한 디 렉 터 리 의 그림 파일 을 찾 는 예 입 니 다.
<?php
class RecursiveFileFilterIterator extends FilterIterator {
    //         
    protected $ext = array('jpg','gif');

    /**
     *    $path            
     */
    public function __construct($path) {
        parent::__construct(new RecursiveIteratorIterator(new RecursiveDirectoryIterator($path)));
    }

    /**
     *              
     */
    public function accept() {
        $item = $this->getInnerIterator();
        if ($item->isFile() && 
                in_array(pathinfo($item->getFilename(), PATHINFO_EXTENSION), $this->ext)) {
            return TRUE;
        }
    }
}

//    
foreach (new RecursiveFileFilterIterator('/path/to/something') as $item) {
    echo $item . PHP_EOL;
}

같은 일 을 하 는 데 더 많은 코드 가 들 지 않 았 습 니까? 그렇다면 위의 코드 를 보면 고도 로 재 활용 되 고 테스트 할 수 있 는 코드 를 가지 고 있 지 않 습 니까? ^)
다음은 SPL 이 제공 하 는 다른 교체 기 입 니 다.
  • RecursiveIterator
  • RecursiveIteratorIterator
  • OuterIterator
  • IteratorIterator
  • FilterIterator
  • RecursiveFilterIterator
  • ParentIterator
  • SeekableIterator
  • LimitIterator
  • GlobIterator
  • CachingIterator
  • RecursiveCachingIterator
  • NoRewindIterator
  • AppendIterator
  • RecursiveIteratorIterator
  • InfiniteIterator
  • RegexIterator
  • RecursiveRegexIterator
  • EmptyIterator
  • RecursiveTreeIterator
  • ArrayIterator

  • PHP 5.3 부터 다른 교체 기 가 내 장 됩 니 다. 전통 코드 를 만 드 는 습관 을 바 꿀 수 있 을 지도 모른다 고 생각 합 니 다.
    SplFixedArray
    SPL 에는 고정 길이 의 배열 을 예화 할 수 있 는 일련의 배열 작업 도구 도 내장 되 어 있 습 니 다. 그렇다면 왜 사용 하 시 겠 습 니까? 더 빠 르 고 심지어 월급 문제 와 관련 이 있 기 때 문 입 니 다. ^)
    PHP 의 일반적인 배열 은 숫자, 문자열 등 다양한 종류의 키 를 포함 하고 있 으 며 길 이 는 가 변 적 이라는 것 을 알 고 있 습 니 다. 바로 이러한 '고급 기능' 때 문 입 니 다. PHP 는 해시 (hash) 방식 으로 키 를 통 해 대응 하 는 값 을 얻 습 니 다. 사실은 특정한 상황 에서 성능 에 문제 가 생 길 수 있 습 니 다.
    SplFixedArray 는 고정된 숫자 키 를 사용 하기 때문에 해시 저장 방식 을 사용 하지 않 습 니 다. 정확히 말 하면 C 배열 이 라 고 생각 할 수도 있 습 니 다. 이것 이 바로 SplFixedArray 가 일반 배열 보다 빠 른 이유 입 니 다 (PHP 5.3 에서 만).
    그것 이 얼마나 빠 른 지 아래 의 그룹 데 이 터 는 당신 에 게 그 결말 을 엿 볼 수 있 습 니 다.
    spl_autoload_unregister
    SplFixedArray 만약 에 대량의 배열 작업 이 필요 하 다 면 그것 이 믿 을 만하 다 고 믿 어 보 세 요.
    데이터 구조
    /upimg/allimg/090614/2244240.jpg. 전통 적 인 변수 형식 으로 데이터 구 조 를 설명 할 수 있 습 니 다. 예 를 들 어 스 택 (Strack) 을 배열 로 설명 한 다음 에 해당 하 는 방식 으로 pop 과 push (array pop (), array push () 를 사용 할 수 있 지만 항상 조심해 야 합 니 다. 데이터 구 조 를 설명 하 는 것 이 아니 기 때문에 한 번 의 오 작 동 으로 스 택 을 파괴 할 수 있 습 니 다.
    더 자세 한 평 가 는 여기 참고 하 셔 도 됩 니 다. 대상 은 엄 격 히 스 택 형식 으로 데 이 터 를 설명 하고 이에 대응 하 는 방법 을 제공 합 니 다. 또한 이러한 코드 는 특정한 배열 이 아 닌 스 택 을 조작 하고 있 음 을 이해 하여 동료 들 이 해당 하 는 코드 를 잘 이해 하고 빠 를 수 있 습 니 다.
    마지막 으로 위 와 같은 창백 한 예 는 아직 부족 할 것 입 니 다. "유혹 합 니 다" 는 SPL 을 사용 합 니 다. 진정한 지식 을 실천 하려 면 SPL 이 더 많 고 더 강 한 기능 을 발굴 해 야 합 니 다. 보석 처럼 천천히 조각 해 야 빛 을 발 할 수 있 습 니 다.
    PS, SPL 에 관 한 상세 한 중국어 문서 입 니 다. 완 일 봉 학생 은 여기 더 상세 한 노트 인 이 있 습 니 다. 추천 합 니 다.

    좋은 웹페이지 즐겨찾기