溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

php設(shè)計(jì)模式中處理樹形結(jié)構(gòu)數(shù)據(jù)怎么使用

發(fā)布時(shí)間:2020-08-07 09:39:57 來源:億速云 閱讀:153 作者:Leah 欄目:編程語(yǔ)言

本篇文章為大家展示了php設(shè)計(jì)模式中處理樹形結(jié)構(gòu)數(shù)據(jù)怎么使用,代碼簡(jiǎn)明扼要并且容易理解,絕對(duì)能使你眼前一亮,通過這篇文章的詳細(xì)介紹希望你能有所收獲。

 關(guān)于組合模式,千萬不要從字面理解,它和我們理解的組合關(guān)系沒什么關(guān)系,它是用來處理樹狀結(jié)構(gòu)的數(shù)據(jù)。因?yàn)樗荒芴幚順湫谓Y(jié)構(gòu)的數(shù)據(jù),所以在日常中并不是很常用,但如果滿足了樹形結(jié)構(gòu),使用該模式就能非常好的處理,能夠大大減少代碼量,寫出的代碼簡(jiǎn)潔明了。

定義

組合模式是一種結(jié)構(gòu)型設(shè)計(jì)模式, 你可以使用它將對(duì)象組合成樹狀結(jié)構(gòu), 并且能像使用獨(dú)立對(duì)象一樣使用它們。它的核心就在于遞歸,通過遞歸來依次處理樹形結(jié)構(gòu)數(shù)據(jù)。

場(chǎng)景

文件目錄樹就是一個(gè)典型的樹形結(jié)構(gòu)的數(shù)據(jù)。下面展示一個(gè)用于計(jì)算文件或目錄大小的功能的類,主要有兩個(gè)方法,添加子節(jié)點(diǎn)(子樹)addNode,統(tǒng)計(jì)文件或目錄大小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

測(cè)試代碼如下:

$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);

// 計(jì)算目錄/app/b大小
echo $node3->fileSize() . 'B' . PHP_EOL; // 2000
// 計(jì)算/app目錄大小
echo $node0->fileSize() . 'B' . PHP_EOL; // 4000

總結(jié)

組合模式,將一組對(duì)象組織成樹形的結(jié)構(gòu),然后將對(duì)象看做是樹的節(jié)點(diǎn)。利用樹形的數(shù)據(jù)結(jié)構(gòu),使用遞歸來處理每個(gè)子樹,依次來簡(jiǎn)化代碼實(shí)現(xiàn)。因?yàn)樵撃J綄?duì)于數(shù)據(jù)有嚴(yán)格的要求,所以在日常中用到的并不多。如想使用該模式,需要你對(duì)業(yè)務(wù)場(chǎng)景非常的了解,然后能把數(shù)據(jù)抽象成樹形結(jié)構(gòu)。一般我們常見的有,文件的目錄樹、無限極分類的處理等等。

上述內(nèi)容就是php設(shè)計(jì)模式中處理樹形結(jié)構(gòu)數(shù)據(jù)怎么使用,你們學(xué)到知識(shí)或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識(shí)儲(chǔ)備,歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI