成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

php設(shè)計(jì)模式中處理樹形結(jié)構(gòu)數(shù)據(jù)怎么使用-創(chuàng)新互聯(lián)

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

網(wǎng)站建設(shè)哪家好,找創(chuàng)新互聯(lián)!專注于網(wǎng)頁設(shè)計(jì)、網(wǎng)站建設(shè)、微信開發(fā)、小程序定制開發(fā)、集團(tuán)企業(yè)網(wǎng)站建設(shè)等服務(wù)項(xiàng)目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了炎陵免費(fèi)建站歡迎大家使用!

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

定義

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

場景

文件目錄樹就是一個(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

測試代碼如下:

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

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

上述內(nèi)容就是php設(shè)計(jì)模式中處理樹形結(jié)構(gòu)數(shù)據(jù)怎么使用,你們學(xué)到知識或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識儲備,歡迎關(guān)注創(chuàng)新互聯(lián)-成都網(wǎng)站建設(shè)公司行業(yè)資訊頻道。

當(dāng)前名稱:php設(shè)計(jì)模式中處理樹形結(jié)構(gòu)數(shù)據(jù)怎么使用-創(chuàng)新互聯(lián)
分享網(wǎng)址:http://jinyejixie.com/article12/dehcdc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供關(guān)鍵詞優(yōu)化、網(wǎng)站內(nèi)鏈微信小程序、網(wǎng)站設(shè)計(jì)公司、服務(wù)器托管移動網(wǎng)站建設(shè)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

網(wǎng)站建設(shè)網(wǎng)站維護(hù)公司
濮阳县| 黄浦区| 邹平县| 电白县| 晋城| 金乡县| 海口市| 米泉市| 克拉玛依市| 烟台市| 合肥市| 孟州市| 定襄县| 河西区| 嘉禾县| 本溪市| 明星| 牟定县| 海伦市| 广东省| 阿拉善右旗| 沙河市| 沁阳市| 嘉黎县| 西乌| 顺义区| 新野县| 贵南县| 乐亭县| 同江市| 永康市| 玛纳斯县| 上杭县| 上杭县| 广德县| 汝阳县| 大方县| 万盛区| 江永县| 乌拉特前旗| 安图县|