Я занимаюсь разработкой C89 для Visual Studio 2010 Ultimate Beta (Win 7). Я не думаю, что я использую malloc()
правильно. Я новичок в C, поэтому, пожалуйста, извините вопрос новичка.
Цель моей программы - подсчитать вхождение слов в **argv
с помощью дерева.
hist.c
#include "tree.h"
#include <stdlib.h>
int main(int argc, char *argv[]) {
unsigned int i;
struct tree *tree;
tree = new_tree();
for (i = 1; i < argc; i++) {
tree_add(tree, argv[i]);
}
tree_dump(tree);
tree_free(tree);
return 0;
}
tree_add.c:
#include "tree.h"
#include <stdlib.h>
#include <string.h>
struct tree *tree_add(struct tree *tree, char *value) {
if (tree == NULL) {
tree = new_tree();
tree->value = value;
tree->count = 0;
}
else if (tree->value == NULL) {
tree->value = value;
}
else if (tree->value == value) {
tree->count++;
}
else if (strcmp(value, tree->value) < 0) {
tree_add(tree->left, value);
}
else if (strcmp(value, tree->value) > 0) {
tree_add(tree->right, value);
}
}
struct tree *new_tree() {
struct tree * tree;
tree = malloc(sizeof *tree);
tree->left = NULL;
tree->right = NULL;
tree->value = NULL;
tree->count = 0;
return tree;
}
Я получаю ошибку:
0xC0000005: чтение о нарушении доступа
местоположение 0x00000000.
Я посмотрел онлайн, и похоже, что эта ошибка вызвана попыткой доступа к неправильно выделенной памяти. Так что я делаю не так?
ОБНОВЛЕНО код для отражения комментариев. Теперь у меня новая проблема. Это условие не работает должным образом, когда value == "x"
и tree->value == "x"
else if (tree->value == value) {
В отладчике я вижу, что tree->value
это 0x00553373 "x" char *
, тогда как value
это 0x00553375 "x" char *
. Шестнадцатеричное значение отличается от последней цифры. Что здесь не так? Я неправильно проверяю равенство строк?