动态链表的创建、节点内存空间申请以及释放

1.动态链表的初始化:

typedef struct _STACK{

    void* data;
    int size;
    struct _STACK* next;
    struct _STACK* pre;

} STACK;

STACK *stack;

STACK *_stack;

void initStack()

stack = (STACK*)malloc(sizeof(STACK));
stack->data    = (DATA*)malloc(sizeof(DATA));
stack->size    = sizeof(DATA);
stack->next = NULL;
stack->pre = NULL;
_stack = NULL;

2.创建和内存申请:

void creatStack()

if(_stack == NULL) {
        _stack = stack;
    }else {
        STACK* pStack = (STACK*)malloc(sizeof(STACK));
        pStack->data = (DATA*)malloc(sizeof(DATA));
        pStack->size = sizeof(STACK);
        pStack->next = NULL;

        _stack->next = pStack;
        pStack->pre = _stack;
        _stack = _stack->next;
    }

3.释放内存

void releaseStack()


DATA* data;

while(NULL != stack)
    {
        STACK* sta = stack;
        stack = stack->next;
        data  = (DATA*)sta->data;
        if(data->type == Array)
            free(data->t.a.valp);
        free(sta->data);
        free(sta);
    }

}

  • 6
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值