【发布时间】:2015-05-13 13:26:31
【问题描述】:
我正在使用以下代码。正如我在 .Net 内存分析器中看到的那样,我发现内存泄漏正在发生。
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows;
using System.Windows.Forms;
using System.ComponentModel;
using System.Windows.Controls;
using System.Windows.Data;
using System.Windows.Documents;
using System.Windows.Input;
using System.Windows.Media;
using System.Windows.Media.Imaging;
using System.Windows.Navigation;
using System.Windows.Shapes;
namespace TestMemLeak
{
public partial class MainWindow : Window
{
public int count = 0;
BackgroundWorker worker = new BackgroundWorker();
public class test
{
public int sno{get; set;}
public string col1 { get; set; }
public string col2 { get; set; }
public string col3 { get; set; }
public string col4 { get; set; }
public string col5 { get; set; }
public string col6 { get; set; }
public string col7 { get; set; }
}
// test test1 = new test();
public MainWindow()
{
InitializeComponent();
worker.WorkerReportsProgress = true; // For Background Worker
worker.DoWork += worker_DoWork;
worker.ProgressChanged += worker_ProgressChanged;
worker.WorkerSupportsCancellation = true;
worker.RunWorkerCompleted += worker_RunWorkerCompleted;
}
private void Load_Click(object sender, RoutedEventArgs e)
{
dg1.Items.Clear();
worker.RunWorkerAsync();
}
void worker_DoWork(object sender, DoWorkEventArgs e)
{
// int max = (int)e.Argument;
for (int i = 1; ; i++)
{
(sender as BackgroundWorker).ReportProgress(i);
System.Threading.Thread.Sleep(1);
if (worker.CancellationPending)
{
e.Cancel = true;
return;
}
}
}
void worker_ProgressChanged(object sender, ProgressChangedEventArgs e)
{
int i = e.ProgressPercentage;
if (i > 100000)
{
count++;
if (count == 100)
{
for (int k = 0; k < 100; k++)
{ dg1.Items.RemoveAt(0); }
count = 0;
}
}
dg1.Items.Add(new test() {sno=i,col1="test",col2="test",col3="test",col4="test",col5="test",col6="test",col7="test" });
}
void worker_RunWorkerCompleted(object sender, RunWorkerCompletedEventArgs e)
{
if (e.Cancelled)
{
System.Windows.MessageBox.Show("Task Cancelled.....");
}
// Check to see if an error occurred in the background process.
else if (e.Error != null)
{
System.Windows.MessageBox.Show("Error while performing background operation." + e.Error.Message);
}
else
{
// Everything completed normally.
System.Windows.MessageBox.Show("Task Completed..." + e.Result);
}
}
private void Stop_Click(object sender, RoutedEventArgs e)
{
worker.CancelAsync();
}
private void Clear_Click(object sender, RoutedEventArgs e)
{
// worker.CancelAsync();
dg1.Items.Clear();
// GC.Collect();
}
}
}
每次我创建一个新的类测试时,它都会占用内存并且不会被 GC 释放。我怎样才能避免这种情况?
【问题讨论】:
-
你只是在DataGrid中添加和清除项目,这些操作会导致内存泄漏吗?
-
您能否添加内存分析器的输出,显示其中一个泄漏项目的 GC 根路径?另外,你的测试程序是什么?什么时候抓快照?
-
您是否遇到了 OutOfmemoryException,或者您只是在查看应用程序使用的内存? GC.Collec()t 不会清除所有未使用的引用。您可能需要调用 GC.Collect(2),因为 Items 可能被视为长期存在的对象:msdn.microsoft.com/en-us/library/ee787088(v=vs.110).aspx
标签: c# wpf memory memory-leaks backgroundworker