成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Node.JavaScript文件系統中目錄的操作

開發 前端
談到對目錄的操作,需要涉及到對目錄遍歷,其實目錄也是我們可以把它看成一顆樹。樹是一種非線性的數據結構,被用來存儲具有層級關系的數據,還被用來存儲有序列表,其中有一種特殊的樹:二叉樹。

[[351532]]

 談到對目錄的操作,需要涉及到對目錄遍歷,其實目錄也是我們可以把它看成一顆樹。樹是一種非線性的數據結構,被用來存儲具有層級關系的數據,還被用來存儲有序列表,其中有一種特殊的樹:二叉樹。

有一種特殊的二叉樹叫二叉查找樹(BST),其他的特點是:相對較小的值保存在左節點中,較大的值保存在右節點中,因為這個特點使查找的效率特別高。

遍歷二叉查找樹有三種方式:中序,先序和后序

中序:按照節點上的鍵值,已升序訪問樹中所有節點,先訪問左子樹,在訪問根節點,最后訪問右子樹。

中序

先序:先訪問根節點,然后以同樣方式訪問左子樹和右子樹

先序

后序:先訪問葉子節點,從左子樹到右子樹,再到根節點

后序 

還有兩種搜索方法:深度優先搜索和廣度優先搜索

深度優先搜索時從一條路徑的起始頂點開始一直到最后一個頂點,然后回溯,繼續追溯下一條路徑,直到到達最后的頂點,如此往復,知道沒有路徑為止。

深度優先搜索

廣度優先搜索是從第一個頂點開始,首先檢查最靠近第一個頂點的一層,再逐漸向下移動到離起始頂點最遠的一層。

廣度優先搜索 

同步創建目錄

_fs.accessSync_是fs.access的同步方法用于檢查文件是否存在,檢查是否對文件是否有讀寫權限,當操作成功時返回值和異步方法執行成功相同,但操作失敗時會拋出異常。

_fs.mkdirSync_是同步創建目錄

話不多說,我們直接上代碼

  1. let fs = require("fs"); 
  2. let path = require("path"
  3. function mkdirSync(paths){ 
  4.     let arr = paths.split("/"); 
  5.     for(let i=0;i<arr.length;i++){ 
  6.      let currentPath = arr.slice(0,i+1).join("/"); 
  7.         try{  
  8.          fs.accessSync(currentPath) //如果路徑存在  不創建目錄 
  9.         }catch(e){ 
  10.            fs.mkdirSync(currentPath) 
  11.         } 
  12.      } 
  13.  } 
  14.  
  15. mkdirSync("a/b/c/d")  //默認創建目錄  必須父級存在 才能創建子級 

 異步創建目錄

  1. function mkdir(paths,cb){ 
  2.     let arr = paths.split("/"); 
  3.     function next(index){ 
  4.        if(index>=arr.length) return cb(); 
  5.        let currentPath = arr.slice(0,index+1).join("/"); 
  6.        fs.access(currentPath,(err)=>{ 
  7.           if(err){  
  8.               fs.mkdir(currentPath,()=>next(index+1)) 
  9.           }else{   //如果存在則不創建 
  10.               next(index+1) 
  11.           } 
  12.        }) 
  13.     } 
  14.     next(0) 
  15. mkdir("a/b/c/d/e",(err)=>{ 
  16.    console.log("創建完成"); 
  17. }) 

創建目錄 

深度刪除目錄(同步)

fs.stat() 方法用于查詢文件信息,可以用于查詢文件的大小、創建時間、權限等相關信息。fs.stat() 是異步方法,還有一個同步方法 fs.statSync(path)返回一個對象

思路是:一個分支上先刪除兒子再刪除自己,然后到另一個分支上刪除兒子再刪除自己。

  1. function removeSync(dir){ 
  2.    let statObj = fs.statSync(dir) 
  3.    if(statObj.isDirectory()){ 
  4.       let dirs = fs.readdirSync(dir)   //返回一個數組 
  5.     //   console.log(dirs); 
  6.      for(let i = 0;i<dirs.length;i++){ 
  7.         //把路徑進行包裝 
  8.          let current =path.join(dir,dirs[i]) 
  9.          removeSync(current) //刪除兒子節點 再將自己刪除 
  10.      } 
  11.      fs.rmdirSync(dir)  //刪除自己 
  12.    }else
  13.        //文件就刪除 
  14.        fs.unlinkSync(dir) 
  15.    } 
  16. removeSync("a"

 廣度刪除目錄(同步)

思路:通過while循環橫向列出所有文件的路徑,然后通過倒敘刪除。

  1. while(current = arr[index++]){ 
  2.     let statObj = fs.statSync(current); 
  3.     if(statObj.isDirectory()){ 
  4.         let dirs =fs.readdirSync(current); 
  5.         dirs = dirs.map(d=>path.join(current,d)); //當前兒子的文件夾路徑 
  6.         arr = [...arr,...dirs] 
  7.     } 
  8.  } 

結果:[ 'a', 'a\b', 'a\b\c', 'a\b\c\d' ]

  1. function wideSync(dir){ 
  2.    let arr = [dir]; 
  3.    let index = 0; 
  4.    let current; //讀取的當前項目 
  5.    while(current = arr[index++]){ 
  6.       let statObj = fs.statSync(current); 
  7.       if(statObj.isDirectory()){ 
  8.           let dirs =fs.readdirSync(current); 
  9.           dirs = dirs.map(d=>path.join(current,d)); //當前兒子的文件夾路徑 
  10.           arr = [...arr,...dirs] 
  11.       } 
  12.    } 
  13.    //倒敘刪除 
  14.    for(let i = arr.length-1;i>=0;i--){ 
  15.        let current = arr[i] 
  16.        let statObj = fs.statSync(current); 
  17.        if(statObj.isDirectory()){ 
  18.            fs.rmdirSync(current
  19.        }else
  20.            fs.unlinkSync(current
  21.        } 
  22.    } 
  23. wideSync("a"

深度刪除目錄(串行異步) 

  1. function rmdirSeries(dir,callback){ 
  2.     fs.stat(dir,(err,statObj)=>{ 
  3.         if(statObj.isDirectory()){ 
  4.              //讀取文件內容 
  5.              fs.readdir(dir,(err,dirs)=>{ 
  6.                  dirs = dirs.map(d=>path.join(dir,d)) 
  7.                  function next(index){ 
  8.                     if(index == dirs.length) return fs.rmdir(dir,callback) 
  9.                     //先取出數組中的第一個  第一個刪除后  在刪第二個 
  10.                     rmdirSeries(dirs[index],()=>next(index+1)) 
  11.                  } 
  12.                  next(0) 
  13.              }) 
  14.         }else
  15.             fs.unlink(dir,callback) 
  16.         } 
  17.     }) 
  18. rmdirSeries("a",()=>{ 
  19.     console.log("刪除成功"); 
  20. }) 

深度刪除目錄(并行異步)

  1. function removeDirParalle(dir,callback){ 
  2.     fs.stat(dir,(err,statObj)=>{ 
  3.         if(statObj.isDirectory()){ 
  4.              //讀取文件內容 
  5.              fs.readdir(dir,(err,dirs)=>{ 
  6.                  if(dirs.length == 0){ 
  7.                     return fs.rmdir(dir,callback) 
  8.                  } 
  9.                  dirs = dirs.map(d=>{ 
  10.                     let current = path.join(dir,d); 
  11.                     //每個人刪除之后就調用done        
  12.                     removeDirParalle(current,done); 
  13.                     return current 
  14.                  }) 
  15.                  //并發刪除 
  16.                  let index = 0; 
  17.                  function done(){ 
  18.                      if(++index == dirs.length){ 
  19.                         fs.rmdir(dir,callback) 
  20.                      } 
  21.                  } 
  22.              }) 
  23.         }else
  24.             fs.unlink(dir,callback) 
  25.         } 
  26.     }) 
  27. removeDirParalle("a",()=>{ 
  28.     console.log("刪除成功"); 
  29. }) 

 【編輯推薦】

 

責任編輯:姜華 來源: 前端簡報
相關推薦

2010-08-04 17:18:09

nfs文件系統

2010-02-25 14:50:59

Linux文件系統

2010-04-22 14:42:34

Aix操作系統

2010-04-08 15:58:24

Unix操作系統

2010-04-15 16:24:10

Unix操作系統

2009-12-22 11:30:38

Linux操作系統

2009-12-10 14:27:07

Linux操作系統

2017-03-30 10:13:11

Linux內核文件系統

2010-01-08 18:01:03

Ubuntu硬盤操作

2012-06-08 09:16:16

操作系統

2010-04-22 14:45:31

Aix操作系統

2020-07-22 14:53:06

Linux系統虛擬文件

2019-05-29 16:33:32

Linux虛擬系統

2019-05-22 09:00:16

Linux虛擬文件系統

2023-08-05 12:58:51

RPC協議服務端

2017-03-30 11:19:33

Linux文件系統目錄結構

2010-04-30 15:51:48

Unix系統

2013-05-27 14:46:06

文件系統分布式文件系統

2012-07-05 09:52:06

EFS文件加密

2023-12-06 09:32:35

Linux系統
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 日韩在线一区二区三区 | 在线观看视频中文字幕 | 日韩在线资源 | 日干夜干 | 日本精品一区 | 国产精品波多野结衣 | 在线视频第一页 | 亚洲国产成人精品女人久久久野战 | 99精品久久久 | 激情网站在线 | 国产成人免费视频网站高清观看视频 | 欧美一区在线视频 | 中文字幕 在线观看 | 国产99免费| 欧美精品一二三 | 久www| 综合国产| 综合久久av | 亚洲经典一区 | 国产精品一区久久久 | 欧美中国少妇xxx性高请视频 | 91一区二区 | 久久久久久亚洲 | 一区二区免费视频 | 国产精品亚洲第一区在线暖暖韩国 | 精品国产一区二区三区av片 | 99精品久久 | 91一区二区三区在线观看 | 国产一区二区视频免费在线观看 | 久久久久久女 | 免费播放一级片 | 亚洲高清视频在线观看 | 久久免费小视频 | www.狠狠干| 日韩一区二区在线视频 | 日韩中文一区二区三区 | 亚洲日韩中文字幕一区 | 国产小视频在线观看 | 国产高清视频在线观看播放 | 欧美日韩在线视频观看 | 国产精品区一区二区三 |