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

相关推荐
山烛9 分钟前
KNN 算法中的各种距离:从原理到应用
人工智能·python·算法·机器学习·knn·k近邻算法·距离公式
guozhetao22 分钟前
【ST表、倍增】P7167 [eJOI 2020] Fountain (Day1)
java·c++·python·算法·leetcode·深度优先·图论
吃着火锅x唱着歌25 分钟前
LeetCode 611.有效三角形的个数
算法·leetcode·职场和发展
中游鱼1 小时前
如何序列化和反序列化动态 XmlElement ?
windows·microsoft·c#
CHANG_THE_WORLD3 小时前
金字塔降低采样
算法·金字塔采样
不知天地为何吴女士5 小时前
Day32| 509. 斐波那契数、70. 爬楼梯、746. 使用最小花费爬楼梯
算法
小坏坏的大世界5 小时前
C++ STL常用容器总结(vector, deque, list, map, set)
c++·算法
励志要当大牛的小白菜8 小时前
ART配对软件使用
开发语言·c++·qt·算法
qq_513970448 小时前
力扣 hot100 Day56
算法·leetcode
PAK向日葵9 小时前
【算法导论】如何攻克一道Hard难度的LeetCode题?以「寻找两个正序数组的中位数」为例
c++·算法·面试