>백엔드 개발 >PHP 튜토리얼 >PHP 디자인 패턴의 조합 모드 - 트리 구조 데이터 처리

PHP 디자인 패턴의 조합 모드 - 트리 구조 데이터 처리

齐天大圣
齐天大圣원래의
2020-08-05 16:39:491884검색

조합 모드에 관해서는 문자 그대로 받아들이지 마십시오. 우리가 이해하는 조합 관계와는 아무런 관련이 없습니다. 트리 구조에서 데이터를 처리하는 데 사용됩니다. 트리 구조의 데이터만 처리할 수 있기 때문에 일상생활에서 많이 사용되지는 않습니다. 그러나 트리 구조가 만족된다면 이 모드를 사용하면 매우 잘 처리할 수 있어 코드 양을 크게 줄일 수 있고, 만들 수 있습니다. 간결하고 명확하게 작성된 코드.

정의

구성 패턴은 객체를 트리 구조로 결합하여 독립된 객체처럼 사용할 수 있는 구조적 디자인 패턴입니다. 그 핵심은 트리 구조의 데이터를 순차적으로 처리하는 재귀(Recursion)에 있습니다.

Scenario

파일 디렉터리 트리는 전형적인 트리 구조의 데이터입니다. 다음은 파일 또는 디렉토리의 크기를 계산하는 데 사용되는 클래스를 보여줍니다. 여기에는 하위 노드(하위 트리) addNode를 추가하고 파일 또는 디렉토리 fileSize의 크기를 계산하는 두 가지 주요 메소드가 있습니다.

class File
{
    private $path = '';
    private $nodes = [];
    private $fileSize = 0;
    
    public function __construct(string $path, int $fileSize)
    {
        $this->path = $path;
        $this->fileSize = $fileSize;
    }
    
    public function addNode (File $node)
    {
        $this->nodes[] = $node;
    }
    
    public function fileSize ()
    {
        $size = 0;
        foreach ($this->nodes as $node) {
            $size += $node->fileSize();
        }
        return $size;
    }
}

다음 디렉터리 트리가 시뮬레이션되었습니다.

/app

/app/1.txt
/app/a
/app/b

/app/a/a1.txt
/app/b/b1.txt
/app/b/b2.txt

테스트 코드는 다음과 같습니다.

$node0 = new File('/app', 0);

$node1 = new File('/app/1.txt', 1000);
$node2 = new File('/app/a', 0);
$node3 = new File('/app/b', 0);

$node21 = new File('/app/a1.txt', 1000);
$node31 = new File('/app/b1.txt', 1000);
$node32 = new File('/app/b2.txt', 1000);

$node2->addNode($node21);
$node3->addNode($node31);
$node3->addNode($node32);
$node0->addNode($node1);
$node0->addNode($node2);
$node0->addNode($node3);

// 计算目录/app/b大小
echo $node3->fileSize() . 'B' . PHP_EOL; // 2000
// 计算/app目录大小
echo $node0->fileSize() . 'B' . PHP_EOL; // 4000

Summary

Combined 모드는 개체 그룹을 트리 구조로 구성한 다음 개체를 노드로 처리합니다. 나무 . 트리 형태의 데이터 구조를 활용하고 재귀를 사용하여 각 하위 트리를 처리함으로써 코드 구현을 차례로 단순화합니다. 이 모드는 데이터 요구사항이 엄격하기 때문에 일상생활에서는 많이 사용되지 않습니다. 이 모드를 사용하려면 비즈니스 시나리오를 잘 이해하고 데이터를 트리 구조로 추상화할 수 있어야 합니다. 일반적으로 우리가 흔히 보는 것은 파일 디렉터리 트리, Infinitus 분류 처리 등입니다.

위 내용은 PHP 디자인 패턴의 조합 모드 - 트리 구조 데이터 처리의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.