gpt4 book ai didi

c - 如何在非常慢的应用程序中查找内存泄漏?

转载 作者:太空宇宙 更新时间:2023-11-03 23:32:23 24 4
gpt4 key购买 nike

我有一个用 C 编写的程序,它使用 Berkeley-Db、glib-2 和 libxml-2。它是一个搜索索引器,使 NLP 具有句法和语义分析,并将概念结构存储在搜索索引中而不是单词中。

但是,我遇到了一个问题——大约一天后,我的程序内存不足。

当我尝试在 valgrind 下运行我的程序时,它运行起来非常慢,在我看来,比正常运行慢 10 倍。

我所有检查内存泄漏的尝试(在 valgrind 下进行了数周左右)没有显示任何泄漏。

有人知道可以在这种情况下帮助我的工具吗?

最佳答案

我的解决方案是:

#define malloc(size) mymalloc(size, __FILE__, __FUNCTION__, __LINE__)
... (realloc, calloc, free)

void *mymalloc(size_t size, char *file, char *function, int line)
{
void *data = malloc(size);
addList(data, size, file, function, line);
return data;
}

void myfree(void *data)
{
removeList(data);
free(data);
}

void debugalloc()
{
printList();
}

removeList() 将在全局列表中搜索“数据”并将其删除,或者给出警告。使用“debugalloc();”你应该打印整个列表(通常它应该是空的,或者填满你期望的内容)。

另一种选择:你的内存管理变得支离 splinter ,...(upps,Alexey Frunze 就在一秒钟前在评论部分写道。)

伊迪丝:XML

我对 DOM 和 SAX 做了一个评论,我的感觉只是扩展​​这个评论:

<head><data>...</data><data>...</data>......<data>...</data></head>

是 SAX 的优秀候选者。在 DOM 中,整个 XML 将被读取并转换到内存中,如果 本身由不同大小的值构成,这会很快导致内存碎片化。可能会发生,您的操作系统的内存模型将反对分配少量内存。

使用 SAX,您只需将部分数据加载到内存中,并在使用后立即将其删除。但是您的实现必须从遍历文档转变为一种具有馈送 (< data >) 和消费/处理 () 的状态机。

关于c - 如何在非常慢的应用程序中查找内存泄漏?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12672770/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com