自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

Node.JavaScript文件系統(tǒng)中目錄的操作

開發(fā) 前端
談到對(duì)目錄的操作,需要涉及到對(duì)目錄遍歷,其實(shí)目錄也是我們可以把它看成一顆樹。樹是一種非線性的數(shù)據(jù)結(jié)構(gòu),被用來存儲(chǔ)具有層級(jí)關(guān)系的數(shù)據(jù),還被用來存儲(chǔ)有序列表,其中有一種特殊的樹:二叉樹。

[[351532]]

 談到對(duì)目錄的操作,需要涉及到對(duì)目錄遍歷,其實(shí)目錄也是我們可以把它看成一顆樹。樹是一種非線性的數(shù)據(jù)結(jié)構(gòu),被用來存儲(chǔ)具有層級(jí)關(guān)系的數(shù)據(jù),還被用來存儲(chǔ)有序列表,其中有一種特殊的樹:二叉樹。

有一種特殊的二叉樹叫二叉查找樹(BST),其他的特點(diǎn)是:相對(duì)較小的值保存在左節(jié)點(diǎn)中,較大的值保存在右節(jié)點(diǎn)中,因?yàn)檫@個(gè)特點(diǎn)使查找的效率特別高。

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

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

中序

先序:先訪問根節(jié)點(diǎn),然后以同樣方式訪問左子樹和右子樹

先序

后序:先訪問葉子節(jié)點(diǎn),從左子樹到右子樹,再到根節(jié)點(diǎn)

后序 

還有兩種搜索方法:深度優(yōu)先搜索和廣度優(yōu)先搜索

深度優(yōu)先搜索時(shí)從一條路徑的起始頂點(diǎn)開始一直到最后一個(gè)頂點(diǎn),然后回溯,繼續(xù)追溯下一條路徑,直到到達(dá)最后的頂點(diǎn),如此往復(fù),知道沒有路徑為止。

深度優(yōu)先搜索

廣度優(yōu)先搜索是從第一個(gè)頂點(diǎn)開始,首先檢查最靠近第一個(gè)頂點(diǎn)的一層,再逐漸向下移動(dòng)到離起始頂點(diǎn)最遠(yuǎn)的一層。

廣度優(yōu)先搜索 

同步創(chuàng)建目錄

_fs.accessSync_是fs.access的同步方法用于檢查文件是否存在,檢查是否對(duì)文件是否有讀寫權(quán)限,當(dāng)操作成功時(shí)返回值和異步方法執(zhí)行成功相同,但操作失敗時(shí)會(huì)拋出異常。

_fs.mkdirSync_是同步創(chuàng)建目錄

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

  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) //如果路徑存在  不創(chuàng)建目錄 
  9.         }catch(e){ 
  10.            fs.mkdirSync(currentPath) 
  11.         } 
  12.      } 
  13.  } 
  14.  
  15. mkdirSync("a/b/c/d")  //默認(rèn)創(chuàng)建目錄  必須父級(jí)存在 才能創(chuàng)建子級(jí) 

 異步創(chuàng)建目錄

  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{   //如果存在則不創(chuàng)建 
  10.               next(index+1) 
  11.           } 
  12.        }) 
  13.     } 
  14.     next(0) 
  15. mkdir("a/b/c/d/e",(err)=>{ 
  16.    console.log("創(chuàng)建完成"); 
  17. }) 

創(chuàng)建目錄 

深度刪除目錄(同步)

fs.stat() 方法用于查詢文件信息,可以用于查詢文件的大小、創(chuàng)建時(shí)間、權(quán)限等相關(guān)信息。fs.stat() 是異步方法,還有一個(gè)同步方法 fs.statSync(path)返回一個(gè)對(duì)象

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

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

 廣度刪除目錄(同步)

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

  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)); //當(dāng)前兒子的文件夾路徑 
  6.         arr = [...arr,...dirs] 
  7.     } 
  8.  } 

結(jié)果:[ '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; //讀取的當(dāng)前項(xiàng)目 
  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)); //當(dāng)前兒子的文件夾路徑 
  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.              //讀取文件內(nèi)容 
  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.                     //先取出數(shù)組中的第一個(gè)  第一個(gè)刪除后  在刪第二個(gè) 
  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.              //讀取文件內(nèi)容 
  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.                     //每個(gè)人刪除之后就調(diào)用done        
  12.                     removeDirParalle(current,done); 
  13.                     return current 
  14.                  }) 
  15.                  //并發(fā)刪除 
  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. }) 

 【編輯推薦】

 

責(zé)任編輯:姜華 來源: 前端簡(jiǎn)報(bào)
相關(guān)推薦

2010-08-04 17:18:09

nfs文件系統(tǒng)

2010-02-25 14:50:59

Linux文件系統(tǒng)

2010-04-08 15:58:24

Unix操作系統(tǒng)

2010-04-15 16:24:10

Unix操作系統(tǒng)

2010-04-22 14:42:34

Aix操作系統(tǒng)

2009-12-22 11:30:38

Linux操作系統(tǒng)

2009-12-10 14:27:07

Linux操作系統(tǒng)

2017-03-30 10:13:11

Linux內(nèi)核文件系統(tǒng)

2010-01-08 18:01:03

Ubuntu硬盤操作

2012-06-08 09:16:16

操作系統(tǒng)

2010-04-22 14:45:31

Aix操作系統(tǒng)

2020-07-22 14:53:06

Linux系統(tǒng)虛擬文件

2019-05-29 16:33:32

Linux虛擬系統(tǒng)

2019-05-22 09:00:16

Linux虛擬文件系統(tǒng)

2023-08-05 12:58:51

RPC協(xié)議服務(wù)端

2017-03-30 11:19:33

Linux文件系統(tǒng)目錄結(jié)構(gòu)

2022-08-09 15:30:41

Linux

2013-05-27 14:46:06

文件系統(tǒng)分布式文件系統(tǒng)

2012-07-05 09:52:06

EFS文件加密

2023-12-06 09:32:35

Linux系統(tǒng)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)