- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在在线学习 CS50 类(class),手头的任务是将字典加载到内存中(我使用的是链式哈希表数据结构),并根据中的单词检查文本文件的内容词典。我编写了一个 load() 函数,用于加载字典文件并将每个单词存储到内存中。当所有单词都加载完毕后,该函数返回 true。 Valgrind 显示没有内存泄漏。问题是我有大量的读/写错误。它帮助我查明了它们似乎来自哪里,我一直在互联网上搜索,但似乎无法弄清楚。
相关代码如下:
#include <stdbool.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define HASH_SIZE 10
#define LENGTH 45
typedef struct node
{
char* word;
struct node* next;
} node;
// Globals
node* hashTable[HASH_SIZE];
unsigned int dictionary_size = 0;
/**
* Loads dictionary into memory. Returns true if successful else false.
**/
bool load(const char* dictionary)
{
// Initialize variables
char currentWord[LENGTH + 1];
int tableIndex;
// Open dictionary
FILE* dict = fopen(dictionary, "r");
if (dict == NULL)
return false;
while(fscanf(dict, "%s", currentWord) == 1)
{
// Get hash value of word
tableIndex = hash(currentWord);
// Initialize new node
node* newNode = malloc(sizeof(node));
newNode->word = malloc((strlen(currentWord) + 1) * sizeof(char));
if (newNode == NULL || newNode->word == NULL)
{
printf("Error: Out of memory\n");
return false;
}
// Copy word into new node
strcpy(newNode->word, currentWord);
newNode->next = NULL;
// If no collision, hash word into head of list
if (hashTable[tableIndex] == NULL)
hashTable[tableIndex] = newNode;
// Create a pointer and move down list
else
{
node* ptrNode = hashTable[tableIndex];
while (ptrNode->next != NULL)
ptrNode = ptrNode->next;
// Append node to end of linked list
ptrNode->next = newNode;
}
// Increase dictionary size
dictionary_size++;
// Free word member before actual node
free(newNode->word);
free(newNode);
}
// Close dictionary and return true
fclose(dict);
return true;
}
还有我的 Valgrind:
==32487== Invalid read of size 4
==32487== at 0x8048989: load (my_new_test.c:120)
==32487== by 0x804873D: main (my_new_test.c:53)
==32487== Address 0x423b30c is 4 bytes inside a block of size 8 free'd
==32487== at 0x402B3D8: free (in /usr/lib/valgrind/vgpreload_memcheck-x86- linux.so)
==32487== by 0x80489D3: load (my_new_test.c:132)
==32487== by 0x804873D: main (my_new_test.c:53)
==32487==
==32487== Invalid write of size 4
==32487== at 0x80489AA: load (my_new_test.c:124)
==32487== by 0x804873D: main (my_new_test.c:53)
==32487== Address 0x423b30c is 4 bytes inside a block of size 8 free'd
==32487== at 0x402B3D8: free (in /usr/lib/valgrind/vgpreload_memcheck-x86-linux.so)
==32487== by 0x80489D3: load (my_new_test.c:132)
==32487== by 0x804873D: main (my_new_test.c:53)
==32487==
==32487== Invalid read of size 4
==32487== at 0x8048999: load (my_new_test.c:121)
==32487== by 0x804873D: main (my_new_test.c:53)
==32487== Address 0x423bb24 is 4 bytes inside a block of size 8 free'd
==32487== at 0x402B3D8: free (in /usr/lib/valgrind/vgpreload_memcheck-x86-linux.so)
==32487== by 0x80489D3: load (my_new_test.c:132)
==32487== by 0x804873D: main (my_new_test.c:53)
==32487== HEAP SUMMARY:
==32487== in use at exit: 0 bytes in 0 blocks
==32487== total heap usage: 286,183 allocs, 286,183 frees, 2,584,308 bytes allocated
==32487==
==32487== All heap blocks were freed -- no leaks are possible
==32487==
==32487== For counts of detected and suppressed errors, rerun with: -v
==32487== ERROR SUMMARY: 10000000 errors from 3 contexts (suppressed: 0 from 0)
我对 Valgrind 还很陌生,但从我收集的情况来看,我的问题似乎出在 else 语句中,主要是创建的指针 (node* ptrNode)。有人能看到我看不到的东西吗?任何帮助将不胜感激!
最佳答案
问题很可能是这两行:
free(newNode->word);
free(newNode);
您刚刚将节点添加到哈希表中,然后立即释放它,从而使哈希表中的指针无效,因为它们现在指向已释放的数据。
关于c - Valgrind新手,似乎不能让它开心,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30833114/
我希望 valgrind 在发现第一个错误时停止并退出。 请勿推荐 --vgdb-error=1 :它不会退出 valgrind。您必须连接 gdb 并从那里终止。 --db-attach : 在最近
有人可以快速解释 Valgrind 的工作原理吗?一个例子:它如何知道内存何时被分配和释放? 最佳答案 Valgrind 基本上在“沙箱”中运行您的应用程序。在此沙箱中运行时,它能够插入自己的指令来进
我有一个因 SIGSEGV 而崩溃的应用程序。 --20183-- VALGRIND INTERNAL ERROR: Valgrind received a signal 11 (SIGSEGV) -
我有一个因 SIGSEGV 而崩溃的应用程序。 --20183-- VALGRIND INTERNAL ERROR: Valgrind received a signal 11 (SIGSEGV) -
我想使用 valgrind 检查长时间运行的进程是否存在内存泄漏。我怀疑我所追求的内存泄漏可能仅在执行几个小时后才会发生。我可以在 valgrind 下运行应用程序并获取 valgrind 日志,但这
我想用 valgrind 检查一个长时间运行的进程是否有内存泄漏。我怀疑我所追求的内存泄漏可能仅在执行数小时后才会发生。我可以在 valgrind 下运行应用程序并获得 valgrind 日志,但这样
如何在不通过 valgrind 命令选项启动它的情况下对每个 Process 实例执行 valgrind memcheck。 有没有办法将监控选项保存在进程中,而不是每次都使用 valgrind 命令
我使用了“--trace-children=yes”选项,我还使用了“--trace-children-skip=patt1,patt2,...”选项(过滤掉噪音过程)。但它对我来说仍然很慢,我的多进
我从 Valgrind 得到以下日志: MPK ==5263== 4 bytes in 1 blocks are still reachable in loss record 1 of 84 ==52
如何在 Valgrind 抑制文件中添加注释? 我需要为一个大型项目维护一个 Valgrind 抑制文件。我们从我们链接到的工具中过滤无法修复的错误。随着工具的新版本发布,此文件可能需要随着时间的推移
我有一个大程序要运行。使用 valgrind 需要几个小时才能运行。我听说有一些东西可以让我们为程序中的特定函数调用 valgrind。其余程序将正常执行(没有 valgrind env)。 任何人都
我可以用 valgrind 检测整数溢出缺陷吗?里面的哪个工具可以做到这一点? 最佳答案 Valgrind 没有可以检测整数溢出的工具。 您可能会使用 gcc 选项捕获这些错误: -ftrapv Th
我有一个简单的程序: int main(void) { const char sname[]="xxx"; sem_t *pSemaphor; if ((pSemaphor = sem_o
如何让 Valgrind 准确显示错误发生的位置?我编译了我的程序(通过 PuTTy 在 Windows 机器上通过 Linux 终端)添加了 -g 调试选项。 当我运行 Valgrind 时,我得到
或者最好是全部,而不仅仅是我的代码?我的程序使用 Gtk、Loudmouth 和其他一些东西,而这两个(以及它们背后的一些,libgcrypto、libssl)本身导致了如此多的错误,以至于我无法检测
我想尝试使用 valgrind 进行一些堆损坏检测。通过以下腐败“单元测试”: #include #include #include int main() { char * c = (ch
我看过类似的问题here ,但我的问题是我没有编辑 default.supp 文件的权限。例如,Valgrind 中是否有任何忽略所有抑制文件的命令行选项? 最佳答案 在 Valgrind 3.10.
我在一个运行无限循环的程序上使用 valgrind。 由于memcheck在程序结束后显示内存泄漏,但由于我的程序有无限循环,它永远不会结束。 那么有什么方法可以强制从 valgrind 时不时地转储
我一直在尝试使用 valgrind 查找一些可疑的内存错误。 在被分析的程序甚至到达我希望分析的点之前,它会因为对 mmap 的调用开始失败而退出。当它不在 valgrind 下时,这些调用会成功。
由于 OpenSSL 使用未初始化的内存,因此对使用 openldap2 的 libldap 的程序进行 Valgrind 是一件苦差事。存在一个 --ignore-fn选项,但仅适用于 Valgri
我是一名优秀的程序员,十分优秀!