思路很簡單,從所有Blog Model中解析出所有文章使用的圖片文件名,排除站外引用,放入一個List<string> usedPicList。再遍歷圖片上傳文件夾,把所有圖片文件的結果加入FileInfo[] fiAllPicList。然後比較usedPicList和fiAllPicList,找出所有fiAllPicList中有,而usedPicList中木有的圖片,就是未被任何文章引用的垃圾圖片了。
原先這個比較算法是用傳統方法寫的,很蛋疼,用了兩重循環,一個標志位才解決問題:
復制代碼 代碼如下:
List<FileInfo> garbagePicList = new List<FileInfo>();
for (int k = 0; k < fiAllPicList.Length; k++)
{
bool found = false;
for (int l = 0; l < usedPicList.Count; l++)
{
if (fiAllPicList[k].Name == usedPicList[l].ToString())
{
found = true;
}
}
if (!found)
{
garbagePicList.Add(fiAllPicList[k]);
}
}
今天用LINQ重寫了一下:
復制代碼 代碼如下:
List<FileInfo> garbagePicList = new List<FileInfo>();
var query = from pic in fiAllPicList
where !usedPicList.Contains(pic.Name)
select pic;
garbagePicList = query.ToList();
清晰明了