考虑变量生命周期

问题代码:

void Function(void)

{

    XXXList* list = NULL;

    while (cond)

    {

        ... // 对列表进行了操作

        XXXList_Free(list);

    }

}

显示上述代码产生悬空指针,一般认为问题在于没有遵循Free后指针置NULL的原则,应修改为:

void Function(void)

{

    XXXList* list = NULL;

    while (cond)

    {

        ... // 对列表进行了操作

        XXXList_Free(list);

        list = NULL;

    }

}

但个人认为问题代码的主要问题是没有考虑list的生命周期,在Function中定义,在while中销毁,不协调。可以将list的定义移到while内部。如下:

void Function(void)

{

    while (cond)

{

 XXXList* list = NULL;

        ... // 对列表进行了操作

        XXXList_Free(list);

    }

}

list不置NULL,代码也不错误,至于在这种情况下是否也需要置NULL,这再讨论。相比第一种修改,这种更加协调。

当然第一种修改复杂些,相比比第二种,能处理更多的事情,比如能在while前操作list。但在Function中定义,在while中销毁,list的生命周期的设计有不清楚的地方。要么都在Function定义销毁,要么都在while中。

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值