free之后的NULL和非NULL

来源:互联网 发布:马修博尔顿瓦特知乎 编辑:程序博客网 时间:2024/05/17 07:19

今天写了个链表,需要不断的删除和插入,程序总是无缘无故挂掉,找了N久,终于发现了问题所在。

把一个node free掉,它并非NULL,也就是

if(node!=NULL)

会成立,于是挂掉了。

以前没这个习惯,因为总是直接改变它指向的地址,以后得留意了。

free只是让内存释放,但他指向的东西并非NULL,而是乱码。

free(p);p = NULL;

指向指针的指针:

今天的项目中,我用定义Head指针作为链表的头,当然这个head也存放着数据。

很多时候引用这个链表的时候的时候得这样:

List S *p = Head;
然后利用p对链表做操作。

在一般情况是没什么问题的,但是在多线程的时候问题来了。

由于需求,在线程1:Head指向的数据被我free掉。

free(Head);Head = NULL;
此时,在线程2中有:

List *p = Head;//do somethingif(p!=NULL)  p = p->next; .....
在线程2:do somethind时,刚好线程1我free了Head。

接着线程2继续,p和p->next离奇的不为NULL。

找了N久,再画个图分析一下才发现问题。

p指向的是head的数据的地址,即使Head 改变了,p指向的数据还是原来的地方。

p---------------------->data

head ---------------->data

接着 head--------->null

但是p ---------------data(free后的data,not null)

解决办法:

指向指针的指针:

 List**  p = &Head;if((*p)!=NULL){    //do some thing;}p = &((*p)->next);
结果数据结构就是:

p--------------->head------------------>data


原创粉丝点击