0

我想制作一个旨在复制文件和文件夹的审核工具。

我使用树视图使用递归方法加载文件和文件夹,但是当树视图检查文件和文件夹加载到列表视图中时需要大量时间(21 分钟为 2GB)。这是一个问题。

如何在最短的时间内将文件和文件夹从树视图加载到列表视图以加快计算速度?

这是我的代码:

private void btnAddToListViewCheckedItem_Click(object sender, EventArgs e)
{
    foreach (TreeNode tn in tvLoadTreeviewFromListView.Nodes)
    {

        AddToListView(tn);
    }
}

private void AddToListView(TreeNode tn)
{

    {

        FileInfo file = new FileInfo(tn.Text);

        string[] suffix = { "B", "KB", "MB", "GB", "TB" };
        if (file.Exists)
        {
            int s = 0;
            long size = file.Length;
            while (size >= 1024)
            {
                NO_OF_FILES += 1;
                s++;
                size /= 1024;
            }



            String countFileSize = string.Format("{0}{1}", size, suffix[s]);


            ListViewItem item = lvLoadSelectedFileAndFolder.Items.Add(file.Name);

            item.ImageIndex= sysIcons.GetIconIndex(tn.Text);
            item.SubItems.Add(tn.Text);
            item.SubItems.Add(countFileSize);

        }

        foreach (TreeNode tnx in tn.Nodes)
        {


            for (int i = 0; i < lvLoadSelectedFileAndFolder.Items.Count; i++)
            {
                int ii = 1;
                if (tnx.Text == lvLoadSelectedFileAndFolder.Items[i].SubItems[ii].Text)
                {
                    return;

                }
            }


            if (tnx.Checked)
            {

                AddToListView(tnx);
            }

        }
    }
    catch (Exception ){}

}
4

1 回答 1

0

您的suffix数组基本上是一个常量,但每次AddToListView处理存在的文件名时都会在堆上重新分配。此外,在加载列表视图时暂停 UI 更新。尝试这个 ...

const string[] suffix = { "B", "KB", "MB", "GB", "TB" };

private void btnAddToListViewCheckedItem_Click(object sender, EventArgs e)
{
    try
    {
        lvLoadSelectedFileAndFolder.BeginUpdate();
        foreach (TreeNode tn in tvLoadTreeviewFromListView.Nodes)
        {
            AddToListView(tn);
        }
    }
    finally
    {
        lvLoadSelectedFileAndFolder.EndUpdate();
    }
}
于 2013-03-11T05:41:21.967 回答