• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            woaidongmao

            文章均收錄自他人博客,但不喜標(biāo)題前加-[轉(zhuǎn)貼],因其丑陋,見諒!~
            隨筆 - 1469, 文章 - 0, 評論 - 661, 引用 - 0
            數(shù)據(jù)加載中……

            Windows下文件夾的遍歷

              文件夾遍歷技術(shù)是一種非常有用的技術(shù),在文件的搜索以及殺毒軟件中都使用了這種技術(shù)。以下我將討論如何在Win32下實(shí)現(xiàn)這種技術(shù)。
              文件夾遍歷技術(shù)的核心就是使用遞歸算法,關(guān)于遞歸算法我這里就不多介紹了,不明白的朋友請參閱相關(guān)內(nèi)容。
              以下是我的算法偽代碼:
            void function(LPCTSTR lpszPath)
            {
              開始查找;
              if (沒有找到文件)
                return;
              do
              {
                if (找到的文件是目錄)
                  function(找到的目錄);
                else
                  對文件進(jìn)行操作;
              } while (查找下一個文件并成功);
            }
              實(shí)現(xiàn)這個算法所需要用到的API函數(shù)以及結(jié)構(gòu)體有:
              ·FindFirstFile;
              ·FindNextFile;
              ·WIN32_FIND_DATA。
              在此我假定你已經(jīng)明白了以上函數(shù)及結(jié)構(gòu)體的用法,now let's begin。
              現(xiàn)在我來編寫開始查找的代碼。在這之前,我先假定函數(shù)參數(shù)lpszPath傳入的路徑格式為X:\(根目錄)或X:\Dir(非根目錄),因?yàn)閃in32程序設(shè)計中通常使用的就是這種路徑格式。你一定注意到了,如果路徑是根目錄,它的后邊有一個路徑分隔符“\”,反之則沒有。那么我在寫代碼的時候必須對這兩種情況分別處理。這段代碼如下:
            TCHAR szFind[MAX_PATH];
            lstrcpy(szFind, lpszPath);
            if (!IsRoot(szFind)) // IsRoot是我自己編寫的函數(shù),若參數(shù)是根目錄,則返回true
            lstrcat(szFind, "\\");
            lstrcat(szFind, "*.*"); // 找所有文件
            WIN32_FIND_DATA wfd;
            HANDLE hFind = FindFirstFile(szFind, &wfd);
            if (hFind == INVALID_HANDLE_VALUE) // 如果沒有找到或查找失敗
              return;
              下面我將討論的是如果找到了文件,該怎么辦。不過在此之前,請你進(jìn)入MS-DOS方式,并輸入dir回車,你看到了什么?

              是的,DOS是不會說假話的,不像Windows一樣總把重要的東西隱藏起來不讓你看到——如果你所在的不是根目錄,你將會看到“.”與“..”這兩個目錄——這是在資源管理器中看不到的。從DOS時代走過的朋友們大抵都明白吧,一個點(diǎn)代表的是當(dāng)前目錄,兩個點(diǎn)代表的是上一級目錄。那么我在處理信息時,就一定得把它們兩個過濾出去,原因我在下面解釋。do-while段的代碼如下:
            do
            {
              if (wfd.cFileName[0] == '.')
                continue; // 過濾這兩個目錄
              if (wfd.dwFileAttributes & FILE_ATTRIBUTE_DIRECTORY)
              {
                TCHAR szFile[MAX_PATH];
                if (IsRoot(lpszPath))
                  wsprintf(szFile, "%s%s", lpszPath, wfd.cFileName);
                else
                  wsprintf(szFile, "%s\\%s", lpszPath, wfd.cFileName);
                function(szFile); // 如果找到的是目錄,則進(jìn)入此目錄進(jìn)行遞歸
              }
              else
              {
                // 對文件進(jìn)行操作
              }
            } while (FindNextFile(hFind, &wfd));
            FindClose(hFind); // 關(guān)閉查找句柄
              現(xiàn)在我來解釋為什么要把那兩個帶點(diǎn)的目錄過濾出去。如你所見,如果找到的是目錄,那么進(jìn)入此目錄進(jìn)行遞歸——那么若是當(dāng)前目錄呢?答案很明顯,如果不對其進(jìn)行過濾,那么程序?qū)⑦M(jìn)入“當(dāng)前目錄”進(jìn)行遞歸。是的,如是將導(dǎo)致遞歸無休止地進(jìn)行下去。
              算法就這么多了,由于這是一個極其耗費(fèi)系統(tǒng)資源的算法,因此你在程序中用到它的時候,最好將其放到一個單獨(dú)的線程中運(yùn)行,否則將會導(dǎo)致你的程序在查找過程中沒有任何響應(yīng)。
              附:IsRoot函數(shù)源碼
            BOOL IsRoot(LPCTSTR lpszPath)
            {
              TCHAR szRoot[4];
              wsprintf(szRoot, "%c:\\", lpszPath[0]);
              return (lstrcmp(szRoot, lpszPath) == 0);
            }

            posted on 2008-07-09 18:29 肥仔 閱讀(2290) 評論(2)  編輯 收藏 引用 所屬分類: VC 存檔

            評論

            # re: Windows下文件夾的遍歷  回復(fù)  更多評論   

            如果是文件夾的快捷方式呢?你怎么處理的?
            2011-08-07 19:22 | wsysuper

            # re: Windows下文件夾的遍歷[未登錄]  回復(fù)  更多評論   

            如果是個.xxx文件怎么辦,你也把它過濾掉了!
            2011-09-06 10:11 | xxx
            久久亚洲精品成人无码网站| 伊人久久久AV老熟妇色| 性做久久久久久久久浪潮| 91久久精品视频| 久久狠狠高潮亚洲精品| 麻豆亚洲AV永久无码精品久久| 四虎国产精品成人免费久久| 久久福利青草精品资源站免费| 久久久久亚洲Av无码专| 色综合久久久久无码专区 | 国产精品99久久久久久董美香| 久久综合给合久久狠狠狠97色| 亚洲乱码精品久久久久..| 伊人久久综合精品无码AV专区| 亚洲精品乱码久久久久久按摩| 久久精品中文字幕无码绿巨人| 久久精品人人槡人妻人人玩AV| 久久精品国产99国产电影网| 麻豆精品久久精品色综合| 精品国产青草久久久久福利| 精品久久久久久久中文字幕| 亚洲国产精品综合久久网络| 久久久亚洲裙底偷窥综合| 欧美大香线蕉线伊人久久| 成人亚洲欧美久久久久| 午夜视频久久久久一区| 亚洲精品午夜国产VA久久成人 | 国产呻吟久久久久久久92| 久久久久国色AV免费看图片| 国产精品中文久久久久久久| 人妻精品久久久久中文字幕一冢本 | 99久久精品费精品国产一区二区 | 国产成人精品综合久久久久| 久久人人爽人人爽人人片av高请| 久久精品无码一区二区无码| 久久精品国产亚洲精品| 人妻丰满AV无码久久不卡| 精品久久久久中文字| 久久精品亚洲日本波多野结衣| 国产巨作麻豆欧美亚洲综合久久| 久久无码AV中文出轨人妻|