• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    迪恩网络公众号

检查c#内存泄漏

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

系统环境 windows 7 x64

 

检查工具:ANTS Memory Profiler 7 或者 .NET Memory Profiler 4.0

 

开发的软件为winform / windows service 形式,form配置task和trigger ,service使用quartz定时调度任务。

 

框架:.net framework 4.0/4.5  

 

可能有内存泄漏问题组件:

 

  1. npoi 2.0.1
  2. System.Data.SQLite.1.0.88.0  准备升级致  System.Data.SQLite.1.0.89.0
  3. quartz.net

 

quartz.net 中有 dbcommond 没有dispose 会造成SqliteParameter中的托管内存未释放

 

connection只进行close,未dispose也会造成内存泄漏

 

   

 

检查出的内存泄漏对象

 

  1. Process.GetCurrentProcess() 在commonlogging中频繁调用,居然占用很大内存,20分钟有83万个对象之多,有49个对象未释放。后改为静态变量引用获得的当前线程
  2. IUnityContainer container = GetOrCreateSessionWrapper().unity.CreateChildContainer();

    也许是设计上的bug,在web下,session request各有自己的ioc容器, 且为父容器与子容器的关系,而在winform下,Context的request和session写成没有缓存时,会在每次调用时创建,造成频繁创建子容器,而又无法象web一样释放request级别的所有对象。

  3. 查了2个多星期,交付日期越来越近,更新到quartz.net 2.2 ,quartz net 2.2中仍有 IDbCommond 没有dispose 会造成SqliteParameter中的托管内存未释放
  4. quartz.net 2.2 重写jobstore,获取idbconnection时从线程缓存中获取,并且不关闭connection, 这样可以避免 Sqlite3, List<SQLiteFunction>对象不断变大的问题。
  5. 过程中也发现有大量非托管内存泄漏,也可以尝试 Marshal.Clean..的相关方法释放(目前还没有办法验证)。


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
C#FOR循环语句——打印五角星和菱形发布时间:2022-07-10
下一篇:
C#创建datatable发布时间:2022-07-10
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap