带无效数据成员问题的 C 链表/堆栈

标签 c memory struct stack void-pointers

所以我正在玩堆栈并制作了一个通用的 Stack.h 文件和一个 Stack.c 文件,分别定义了列表及其函数,当我尝试它(stackdemo.c)时,当我从列表。我尝试使用 void ** 节点成员,谨慎对待内存泄漏等,但没有什么能让我克服这一点。我使用 MinGW 32 位 gcc 编译器和 g++ 来链接 Windows 7,没有发出任何警告。

我有预感,每次调用 push 时,我可能都必须重新分配 NODE 结构,因为数据成员是在 NODE 之后分配的> struct 是,但我不知道要分配多少字节。我假设 NODE 结构的 malloc 分配两个指针变量,仅此而已。我不知道当前有任何内存泄漏。

//Stack.h

#ifndef STACK_H
#define STACK_H`
#include "string.h"

typedef struct _Node
{
    size_t size;
    void *data;
    struct _Node *next;
} NODE;
void push(NODE **head, void *data, size_t size);
void pop(NODE **head, void *data);
#endif

和 stack.c

#include "Stack.h"
#include "stdlib.h"
#include "string.h"

void push(NODE **head, void *data,size_t size)
{
    NODE *temp = (NODE *)malloc(sizeof(NODE*));
    temp->size = size;
    temp->data = malloc(size);
    temp->next = *head;
    memcpy(temp->data,data,size);
    *head = temp;
}
void pop(NODE **head, void *data)
{
    NODE *temp = *head;
    if(temp)
    {
        data = malloc(temp->size);
        memcpy(data,temp->data,temp->size);
        *head = temp->next;
        free(temp->data);
        free(temp);
    }
}

测试程序:

#include "Stack.h"
#include "stdio.h"
int main(int argc, char **argv)
{
    int n = 1;
    NODE *head = NULL;
    while(n)
    {
        printf("\nPlease enter a number to push or press -1 to pop, 0 to quit:\t");
        scanf("%d",&n);
        if(n > 0)
        {
            push(&head,&n,sizeof(int));
            printf("Pushed %d on the stack",n);
        }
        else if(n == -1)
        {
            int i;
            pop(&head,&i);
            printf("Popped %d from the stack",i);
        }
    }
}

每次到达 pop() 时都会崩溃

最佳答案

at pop :以下行不是必需的。

data = malloc(temp->size);

推送时:

NODE *temp = (NODE *)malloc(sizeof(NODE*));

应该是

NODE *temp = (NODE *)malloc(sizeof(NODE));

关于带无效数据成员问题的 C 链表/堆栈,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23037690/

相关文章:

c - 关于 "for(a, b&&c, d) {...}"和 "for(a, b, d) if(c) {...}"的区别

c - 如何在C中使用循环在字符数组中输入一个字符?

c - 使用自定义堆的类似 malloc 的函数

Android 内存泄漏 : Multiple instances of activity in multiple threads

c - 为什么 Visual Studio 2015 找不到 libxml2 的文件依赖项 iconv.h?

在 C 中将 JPEG 从 RGB 转换为 HSL

memory - 二维 block 的 CUDA 合并访问

c - 如何将txt文件(包含结构)复制到链表c

c - 如何在 C 结构中实现检索和更新

c++ - 有没有一种简单的方法来判断一个类/结构是否没有数据成员?