我对编程比较陌生,这是我在C中工作的第一个术语。所以完全有可能这可能是一个非常简单的错误,或者也可能解释我做错了什么可能会过去我的脑袋。
我的程序读入文本文件,在hashmap中构建一致性,告诉用户文本中的哪些单词以及它们出现的次数。但是,每当我使用myCompare函数时,我都会继续使用segfault(代码11)。这是它的代码:
int myCompare(void *s1, void *s2)
{
printf("\n\nStarting myCompare...");
printf("\n*s1: %s", (char *)s1);
printf("\n*s2: %s", (char *)s2);
char *key1 = (char *)s1;
printf("\n\nkey1: %s", key1);
char *key2 = (char *)s2;
printf("\nkey2: %s", key2);
return (strcmp(key1, key2));
}
我向它添加了一些打印语句,并且调用它的函数让我更好地了解传递的内容以及它的确切位置,但我不确定它为什么会发生。这是输出,如果有人需要更多的代码来理解我的错误,请告诉我。谢谢你们
struct hashLink {
void* key;
void* value;
struct hashLink * next;
};
struct hashMap {
hashLink ** table;
int tableSize;
int count;
};
...
void removeKey (struct hashMap * ht, void* k, comparator keyCompare, hashFuncPtr hashFunc)
{
struct hashLink *previousLink;
struct hashLink *currentLink;
int index = 0;
printf("\n\nVariables Declared");
printf("\nPre-hash index: %d", index);
index = ((*hashFunc)(k) % ht->tableSize);
void* keyPtr = &ht->table[index]->key;
printf("\nPost-hash index: %d", index);
printf("\nkeyPtr value: %p", keyPtr);
printf("\nk value: %p", k);
int testCompare = (*keyCompare)(k, keyPtr);
printf("\nkeyCompare: %d", testCompare);
if ((*keyCompare)(k, keyPtr) ==)){
... }
终端输出:
Starting hash2...
Passed key: and
value of r: 617
Post-hash index: 7
keyPtr value: 0x10e65dcd8
k value: 0x10e65df24
Starting myCompare...
*s1: and
*s2:
key1: and
key2:
keyCompare: 65
Starting myCompare...
*s1:
*s2: and
key1:
Segmentation fault: 11
logout
答案 0 :(得分:1)
如果您编写段错误,那么您可能正在尝试使用包含垃圾的指针进行操作,并且实际上并未指向您拥有的任何数据。尝试使用valgrind。
编译代码时不进行优化,并包含调试符号
g++ -O0 -g ./your_program.cpp -o ./your_program
使用valgrind的内存检查器
valgrind --leak-check=yes --track-origins=yes ./your_program
valgrind很可能会告诉你代码究竟出了什么问题。