2016-10-25 14:19发布
unix环境高级编程第三版323面到325面那个多线程操作哈希表的例子。
我不懂的是为什么最后释放节点的时候,作者先对节点加锁获取其引用次数,次数为1需要删除节点。然后作者后面解释到,需要释放这个锁才能对哈希表加锁,才能删除节点。请问这是为什么?在这种情况下不就是先获得哈希表锁再获得节点锁,和前面的添加节点加锁顺序相反,还有可能造成死锁啊。
几个函数大致就是这样的结构,前面的就不画图了,最后foo_rele画一个图详细的说一下。如果在第一次判断引用计数为1的时候,不对节点进行解锁,直接从哈希表中摘除并进行释放,这里会出问题。
foo_rele
最多设置5个标签!
几个函数大致就是这样的结构,前面的就不画图了,最后
foo_rele
画一个图详细的说一下。如果在第一次判断引用计数为1的时候,不对节点进行解锁,直接从哈希表中摘除并进行释放,这里会出问题。
一周热门 更多>