通过分析自己的程序,发现有两点原因导致:
一、
1.如出现同样的问题,可以考虑看下自己程序的自定义控件。
2.补充说明:
发现任务管理器-用户对象接近1W 会出现问题。
3.解决方法:
最终原因还是程序控件没有释放:遇到此问题,着重检查这种代码
//ctrl.Controls.Clear();
应改为:
while (ctrl.Controls.Count > 0)
{
Control ct = ctrl.Controls[0];
ctrl.Controls.Remove(ct);
ct.Dispose();
ct = null;
}
二、
上位机Winform程序,需要用GDI技术画图形显示时,当界面上增加很多 对象后,再添加时也会报错"创建窗口句柄时出错";
打开任务管理器,详细信息,添加列,将用户对象和GDI对象显示出来,发现 用户对象也接近1W ;
问题原因:
GDI对象
Windows中将GDI对象和用户对象都限制为最大10000个,可以通过修改注册表来重新设置。
大概原因是 GDI非托管资源 未释放的原因。
解决方法:
1、起初通过抓Dump然后用WinDbg去分析,但是 其内存占用并不大,分析不出啥问题
2、直接从代码入手,一边操作一边看GDI对象的增加,看那个函数调用GDI对象数增加明显。
从添加一个设备的代码 一步步调试跟进,看调用哪个函数时 GDI对象/用户对象,增加的多。
发现一个类库项目中: new Form().CreateGraphics()每次调用都会加5个GDI对象,而这个函数会调用好多次,
于是设置一个静态变量:static Graphics = new Form().CreateGraphics();
修改后 测试发现GDI对象数 趋于正常。