我在连续实例化一个com-wrapper并让GC对其进行收集(非强制性)时遇到了奇怪的现象。
我正在WinCE x86上测试.net cf。使用.net Compact framework远程监视器监控性能。使用平台生成工具包中的Windows CE Remote性能监视器跟踪本机内存。
在前1000个创建的实例期间,每个perfmon计数器都正常:
- GC堆上下波动,但平均值保持不变
- 固定对象为0
- 本机内存保持相同的平均值
- ...
然而,在这1000个实例之后(大约),固定的对象计数器上升,并且数量再也不会下降。然而,内存使用量保持不变。
我不知道如何从这些信息中得出结论...这是计数器中的错误吗?还是我的软件有问题?
[编辑]
我注意到,当GC稳定后,总字节数达到一定值时,固定对象计数器开始上升,未被压缩器移动的对象计数器也是如此。
计数器的图形 http://files.stormenet.be/gc_pinnedobj.jpg
[/编辑]
下面是相关代码:
private void pButton6_Click(object sender, EventArgs e) {
if (_running) {
_running = false;
return;
}
_loopcount = 0;
_running = true;
Thread d = new Thread(new ThreadStart(LoopRun));
d.Start();
}
private void LoopRun() {
while (_running) {
CreateInstances();
_loopcount++;
RefreshLabel();
}
}
void CreateInstances() {
List<Ppb.Drawing.Image> list = new List<Ppb.Drawing.Image>();
for (int i = 0; i < 10; i++) {
Ppb.Drawing.Image g = resourcesObj.someBitmap;
list.Add(g);
}
}
Image对象包含一个AlphaImage:
public sealed class AlphaImage : IDisposable {
IImage _image;
Size _size;
IntPtr _bufferPtr;
public static AlphaImage CreateFromBuffer(byte[] buffer, long size) {
AlphaImage instance = new AlphaImage();
IImage img;
instance._bufferPtr = Marshal.AllocHGlobal((int)size);
Marshal.Copy(buffer, 0, instance._bufferPtr, (int)size);
GetIImagingFactory().CreateImageFromBuffer(instance._bufferPtr, (uint)size, BufferDisposalFlag.BufferDisposalFlagGlobalFree, out img);
instance.SetImage(img);
return instance;
}
void SetImage(IImage image) {
_image = image;
ImageInfo imgInfo;
_image.GetImageInfo(out imgInfo);
_size = new Size((int)imgInfo.Width, (int)imgInfo.Height);
}
~AlphaImage() {
Dispose();
}
#region IDisposable Members
public void Dispose() {
Marshal.FinalReleaseComObject(_image);
}
}