关于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% 马上回收内存。

相关推荐
mifengxing19 分钟前
力扣每日一题——接雨水
c语言·数据结构·算法·leetcode·动态规划·
魔云连洲1 小时前
前端树形结构过滤算法
前端·算法
小龙报1 小时前
《算法通关指南:数据结构和算法篇 --- 顺序表相关算法题》--- 询问学号,寄包柜,合并两个有序数组
c语言·开发语言·数据结构·c++·算法·学习方法·visual studio
切糕师学AI2 小时前
C# 使用 CSRedisCore指南
redis·c#·.net core
小南家的青蛙2 小时前
LeetCode LCR 085 括号生成
算法·leetcode·职场和发展
jackzhuoa2 小时前
Rust 异步核心机制剖析:从 Poll 到状态机的底层演化
服务器·前端·算法
夜晚中的人海2 小时前
【C++】模拟算法习题
c++·算法·哈希算法
花月C2 小时前
算法 - 差分
人工智能·算法·机器学习
拆房老料2 小时前
深入解析提示语言模型校准:从理论算法到任务导向实践
人工智能·算法·语言模型
晨非辰3 小时前
《数据结构风云》递归算法:二叉树遍历的精髓实现
c语言·数据结构·c++·人工智能·算法·leetcode·面试