首頁 後端開發 php教程 php如何使用迭代實現資料夾的複製刪除與查看大小等操作實例分析

php如何使用迭代實現資料夾的複製刪除與查看大小等操作實例分析

Aug 11, 2017 pm 01:15 PM
php 實現 資料夾

這篇文章主要介紹了PHP基於迭代實現資料夾複製、刪除、查看大小等操作的方法,簡單說明了迭代的原理並結合實例形式分析了php採用迭代算法實現文件夾的複製、刪除及查看大小等常見操作的相關實作技巧,需要的朋友可以參考下

本文實例講述了PHP基於迭代實現資料夾複製、刪除、查看大小等操作的方法。分享給大家供大家參考,具體如下:

前面 PHP遞歸實現資料夾的複製、刪除、查看大小操作 分析了遞歸操作使用技巧,這裡再來分析一下迭代的操作技巧。

「既然遞迴能很好的解決,為什麼還要用迭代呢」?主要的原因還是效率問題…

遞歸的概念是函數呼叫自身,把一個複雜的問題分解成與其相似的多個子問題來解決,可以極大的減少程式碼量,使得程式看起來非常優雅。

由於系統要為每次函數呼叫分配運行空間,並使用壓棧予以記錄。在函數呼叫結束後,系統需要釋放空間,並彈棧恢復斷點。所以遞歸的消耗還是比較大的。

即使語言設計時已經將函數呼叫優化的極度完美,達到可以忽略遞歸造成的資源浪費,但是遞歸的深度仍然會受到系統堆疊容量的限制,否則將會拋出 StackOverflowError 錯誤。

而迭代能很好的利用計算機適合做重複操作的特點,並且從理論上說,所有的遞歸函數都可以轉換為迭代函數,所以盡量能不用遞歸就不用遞歸,能用迭代代替就用迭代代替。

檢視資料夾大小

迭代的想法是讓電腦對一組指令重複執行,在每次執行這組指令時,都從變數的原值推出其它的新值…重複這一過程直到達到結束條件或沒有新值產生。

由於遞歸相當於循環加堆疊,所以可以在迭代中使用堆疊來進行遞歸和迭代的轉換。


/**
 * 文件夹大小
 * @param $path
 * @return int
 */
function dirsize($path)
{
  /* 初始条件 */
  $size = 0;
  $stack = array();
  if (file_exists($path)) {
    $path = realpath($path) . '/';
    array_push($stack, '');
  } else {
    return -1;
  }
  /* 迭代条件 */
  while (count($stack) !== 0) {
    $dir = array_pop($stack);
    $handle = opendir($path . $dir);
    /* 执行过程 */
    while (($item = readdir($handle)) !== false) {
      if ($item == '.' || $item == '..') continue;
      $_path = $path . $dir . $item;
      if (is_file($_path)) $size += filesize($_path);
      /* 更新条件 */
      if (is_dir($_path)) array_push($stack, $dir . $item . '/');
    }
    closedir($handle);
  }
  return $size;
}
登入後複製

#複製資料夾

迭代和遞歸都具有初始化變數、判斷結束條件、執行實際操作、產生新變數這四個步驟,只不過所在的位置不同罷了。

例如初始化變數這一步驟,在迭代中是位於函數的起始部分,而在遞迴中是指其他函數傳遞參數這一過程;

判斷結束條件這一步驟,在迭代中用於判斷循環是否繼續,在遞歸中用於判斷遞歸的結束位置;

執行實際操作在遞歸和迭代中都是函數的核心部分,位於產生新變數步驟之前;

產生新變數在迭代中是迭代繼續的條件,在遞歸中是下一次遞歸的基礎,由於產生了新變數才使得遞歸或迭代繼續進行。


/**
 * 复制文件夹
 * @param $source
 * @param $dest
 * @return string
 */
function copydir($source, $dest)
{
  /* 初始条件 */
  $stack = array();
  $target = '';
  if (file_exists($source)) {
    if (!file_exists($dest)) mkdir($dest);
    $source = realpath($source) . '/';
    $dest = realpath($dest) . '/';
    $target = realpath($dest);
    array_push($stack, '');
  }
  /* 迭代条件 */
  while (count($stack) !== 0) {
    $dir = array_pop($stack);
    $handle = opendir($source . $dir);
    if (!file_exists($dest . $dir)) mkdir($dest . $dir);
    /* 执行过程 */
    while (($item = readdir($handle)) !== false) {
      if ($item == '.' || $item == '..') continue;
      $_source = $source . $dir . $item;
      $_dest = $dest . $dir . $item;
      if (is_file($_source)) copy($_source, $_dest);
      /* 更新条件 */
      if (is_dir($_source)) array_push($stack, $dir . $item . '/');
    }
    closedir($handle);
  }
  return $target;
}
登入後複製

刪除資料夾

丟開語言特性影響效能最多的就是冗餘程式碼了,冗餘程式碼通常是由於設計不到位而產生的。

多數情況下遞迴要比迭代冗餘程式碼更多,這也是造成遞迴效率低的一大因素。

但當遞迴程式碼夠簡練,冗餘度夠低時,迭代的效能未必就比遞歸高。

例如這個用迭代實現的資料夾刪除函數,速度就比遞歸慢20%,主要原因是空資料夾的判斷,在遞歸中當資料夾沒有子資料夾時,函數會直接刪除所有檔案和目前資料夾,遞歸結束。

在迭代中即使資料夾為空也需要將其存入堆疊,下次迭代時再判斷是否為空,之後才能刪除。這就相比遞歸多了判斷文件為空、存入堆疊、取出迭代等冗餘操作,所以處理速度會比遞歸更慢。


/**
 * 删除文件夹
 * @param $path
 * @return bool
 */
function rmdirs($path)
{
  /* 初始化条件 */
  $stack = array();
  if (!file_exists($path)) return false;
  $path = realpath($path) . '/';
  array_push($stack, '');
  /* 迭代条件 */
  while (count($stack) !== 0) {
    $dir = end($stack);
    $items = scandir($path . $dir);
    /* 执行过程 */
    if (count($items) === 2) {
      rmdir($path . $dir);
      array_pop($stack);
      continue;
    }
    /* 执行过程 */
    foreach ($items as $item) {
      if ($item == '.' || $item == '..') continue;
      $_path = $path . $dir . $item;
      if (is_file($_path)) unlink($_path);
      /* 更新条件 */
      if (is_dir($_path)) array_push($stack, $dir . $item . '/');
    }
  }
  return !(file_exists($path));
}
登入後複製

查看執行時間

這是檢視程式碼執行時間(毫秒數)的函數,透過回呼方式執行目標程式碼(或函數),最終計算出執行的時間(毫秒)。透過這個工具可以比較函數之間的效能差距,非常簡單實用的一個小工具。


/**
 * 函数执行毫秒数
 * @param $func
 * @return int
 */
function exec_time($func)
{
  $start = explode(' ', microtime());
  $func();// 执行耗时操作
  $end = explode(' ', microtime());
  $sec_time = floatval($end[0]) - floatval($start[0]);
  $mic_time = floatval($end[1]) - floatval($start[1]);
  return intval(($sec_time + $mic_time) * 1000);
}
echo exec_time(function () {
  /* 执行的耗时操作 */
});
登入後複製

以上是php如何使用迭代實現資料夾的複製刪除與查看大小等操作實例分析的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1653
14
CakePHP 教程
1413
52
Laravel 教程
1305
25
PHP教程
1251
29
C# 教程
1224
24
適用於 Ubuntu 和 Debian 的 PHP 8.4 安裝和升級指南 適用於 Ubuntu 和 Debian 的 PHP 8.4 安裝和升級指南 Dec 24, 2024 pm 04:42 PM

PHP 8.4 帶來了多項新功能、安全性改進和效能改進,同時棄用和刪除了大量功能。 本指南介紹如何在 Ubuntu、Debian 或其衍生版本上安裝 PHP 8.4 或升級到 PHP 8.4

在PHP API中說明JSON Web令牌(JWT)及其用例。 在PHP API中說明JSON Web令牌(JWT)及其用例。 Apr 05, 2025 am 12:04 AM

JWT是一種基於JSON的開放標準,用於在各方之間安全地傳輸信息,主要用於身份驗證和信息交換。 1.JWT由Header、Payload和Signature三部分組成。 2.JWT的工作原理包括生成JWT、驗證JWT和解析Payload三個步驟。 3.在PHP中使用JWT進行身份驗證時,可以生成和驗證JWT,並在高級用法中包含用戶角色和權限信息。 4.常見錯誤包括簽名驗證失敗、令牌過期和Payload過大,調試技巧包括使用調試工具和日誌記錄。 5.性能優化和最佳實踐包括使用合適的簽名算法、合理設置有效期、

您如何在PHP中解析和處理HTML/XML? 您如何在PHP中解析和處理HTML/XML? Feb 07, 2025 am 11:57 AM

本教程演示瞭如何使用PHP有效地處理XML文檔。 XML(可擴展的標記語言)是一種用於人類可讀性和機器解析的多功能文本標記語言。它通常用於數據存儲

解釋PHP中的晚期靜態綁定(靜態::)。 解釋PHP中的晚期靜態綁定(靜態::)。 Apr 03, 2025 am 12:04 AM

靜態綁定(static::)在PHP中實現晚期靜態綁定(LSB),允許在靜態上下文中引用調用類而非定義類。 1)解析過程在運行時進行,2)在繼承關係中向上查找調用類,3)可能帶來性能開銷。

php程序在字符串中計數元音 php程序在字符串中計數元音 Feb 07, 2025 pm 12:12 PM

字符串是由字符組成的序列,包括字母、數字和符號。本教程將學習如何使用不同的方法在PHP中計算給定字符串中元音的數量。英語中的元音是a、e、i、o、u,它們可以是大寫或小寫。 什麼是元音? 元音是代表特定語音的字母字符。英語中共有五個元音,包括大寫和小寫: a, e, i, o, u 示例 1 輸入:字符串 = "Tutorialspoint" 輸出:6 解釋 字符串 "Tutorialspoint" 中的元音是 u、o、i、a、o、i。總共有 6 個元

PHP和Python:比較兩種流行的編程語言 PHP和Python:比較兩種流行的編程語言 Apr 14, 2025 am 12:13 AM

PHP和Python各有優勢,選擇依據項目需求。 1.PHP適合web開發,尤其快速開發和維護網站。 2.Python適用於數據科學、機器學習和人工智能,語法簡潔,適合初學者。

什麼是PHP魔術方法(__ -construct,__destruct,__call,__get,__ set等)並提供用例? 什麼是PHP魔術方法(__ -construct,__destruct,__call,__get,__ set等)並提供用例? Apr 03, 2025 am 12:03 AM

PHP的魔法方法有哪些? PHP的魔法方法包括:1.\_\_construct,用於初始化對象;2.\_\_destruct,用於清理資源;3.\_\_call,處理不存在的方法調用;4.\_\_get,實現動態屬性訪問;5.\_\_set,實現動態屬性設置。這些方法在特定情況下自動調用,提升代碼的靈活性和效率。

PHP:網絡開發的關鍵語言 PHP:網絡開發的關鍵語言 Apr 13, 2025 am 12:08 AM

PHP是一種廣泛應用於服務器端的腳本語言,特別適合web開發。 1.PHP可以嵌入HTML,處理HTTP請求和響應,支持多種數據庫。 2.PHP用於生成動態網頁內容,處理表單數據,訪問數據庫等,具有強大的社區支持和開源資源。 3.PHP是解釋型語言,執行過程包括詞法分析、語法分析、編譯和執行。 4.PHP可以與MySQL結合用於用戶註冊系統等高級應用。 5.調試PHP時,可使用error_reporting()和var_dump()等函數。 6.優化PHP代碼可通過緩存機制、優化數據庫查詢和使用內置函數。 7

See all articles