关于C# halcon内存泄漏的研究

开发环境:Win7 VS2002 halcon12, 直接运行Debug的exe

不释放

private void butTemp_Click(object sender, EventArgs e)

{

HOperatorSet.SetSystem("clip_region", "false");

HObject region;

HOperatorSet.GenEmptyRegion(out region);

for (int i = 0; i < 1000; i++)

for (int j = 0; j < 10000; j++)

{

HObject tmpRegion;

HOperatorSet.GenRectangle1(out tmpRegion, i, j, i, j);

HOperatorSet.Union2(tmpRegion, region, out region);

}

HTuple tArea, tmp;

HOperatorSet.AreaCenter(region, out tArea, out tmp, out tmp);

Debug.Assert(tArea > 0);

TestForm form = new TestForm();

form.ShowDialog();

}

不到一分钟运行结束,最多占用1G内存,运行结束占用800M内存。

释放tmpRegio

private void butTemp_Click(object sender, EventArgs e)

{

HOperatorSet.SetSystem("clip_region", "false");

HObject region;

HOperatorSet.GenEmptyRegion(out region);

for (int i = 0; i < 1000; i++)

for (int j = 0; j < 10000; j++)

{

HObject tmpRegion;

HOperatorSet.GenRectangle1(out tmpRegion, i, j, i, j);

HOperatorSet.Union2(tmpRegion, region, out region);

tmpRegion.Dispose();

}

HTuple tArea, tmp;

HOperatorSet.AreaCenter(region, out tArea, out tmp, out tmp);

Debug.Assert(tArea > 0);

TestForm form = new TestForm();

form.ShowDialog();

}

不到一分钟运行结束,最多占用0.5G内存,运行结束占用0.5G 内存。

释放region

private void butTemp_Click(object sender, EventArgs e)

{

HOperatorSet.SetSystem("clip_region", "false");

HObject region;

HOperatorSet.GenEmptyRegion(out region);

for (int i = 0; i < 1000; i++)

for (int j = 0; j < 10000; j++)

{

HObject tmpRegion;

HOperatorSet.GenRectangle1(out tmpRegion, i, j, i, j);

HOperatorSet.Union2(tmpRegion, region, out region);

tmpRegion.Dispose();

}

HTuple tArea, tmp;

HOperatorSet.AreaCenter(region, out tArea, out tmp, out tmp);

Debug.Assert(tArea > 0);

region.Dispose();

TestForm form = new TestForm();

form.ShowDialog();

}

几乎没变化,还是0.5G左右

释放bak

private void butTemp_Click(object sender, EventArgs e)

{

HOperatorSet.SetSystem("clip_region", "false");

HObject region;

HOperatorSet.GenEmptyRegion(out region);

for (int i = 0; i < 1000; i++)

for (int j = 0; j < 10000; j++)

{

HObject tmpRegion;

HOperatorSet.GenRectangle1(out tmpRegion, i, j, i, j);

HObject bak = region;

HOperatorSet.Union2(tmpRegion, region, out region);

bak.Dispose();

tmpRegion.Dispose();

}

HTuple tArea, tmp;

HOperatorSet.AreaCenter(region, out tArea, out tmp, out tmp);

Debug.Assert(tArea > 0);

region.Dispose();

TestForm form = new TestForm();

form.ShowDialog();

}

不到一分钟运行结束,内存几乎没增加,不到20M以内。

结论

Union2的出参和入参一致时,必须手动释放,这样才能100% 马上回收内存。

相关推荐
xb11321 分钟前
数据结构——堆(C语言)
c语言·数据结构·算法
我曾经是个程序员9 分钟前
C#集合排序的三种方法(List<T>.Sort、LINQ 的 OrderBy、IComparable<T> 接口)
开发语言·c#
独正己身18 分钟前
代码随想录day3
数据结构·c++·算法
cqths21 分钟前
.NET 9.0 的 Blazor Web App 项目、Bootstrap Blazor 组件库、自定义日志 TLog 使用备忘
数据库·c#·.net·web app
Mr.L705171 小时前
Maui学习笔记- SQLite简单使用案例02添加详情页
笔记·学习·ios·sqlite·c#
格林威3 小时前
BroadCom-RDMA博通网卡如何进行驱动安装和设置使得对应网口具有RDMA功能以适配RDMA相机
人工智能·数码相机·opencv·计算机视觉·c#
迪小莫学AI3 小时前
【力扣每日一题】LeetCode 2412: 完成所有交易的初始最少钱数
算法·leetcode·职场和发展
c++初学者ABC3 小时前
蓝桥杯LQ1044 求完数
c++·算法·lq蓝桥杯
.zhy.4 小时前
《挑战程序设计竞赛2 算法和数据结构》第二章实现
java·数据结构·算法
Catherinemin4 小时前
剑指Offer|LCR 045.找树左下角的值
javascript·算法