多线程问题

今天解决了两个问题,为期四天的问题终于可以告一段落。心情很是舒畅!

 

程序是一个生成播出表的算法,运行中遇到两个问题:

1. 多线程运行中 内存分配不足的问题。

2. 使用hash表控制重复线程时遇到的,double free问题。

 

 

程序运行于linux Redhat 5.0 操作系统

答:1.内存分配不足是因为线程分配的太快,而旧的线程没有得到释放的问题。linux中线程分为 join和detach。

一般线程默认为join,这种线程只有在内存在函数pthread_join(id)后资源才能得到释放。

而detach线程在运行结束后自动释放资源,用pthread_detach(pthread_self())设置。

 

2.线程1添加hash表并且运行。

线程2获取hash表,发现线程1在运行,准备进入等待状态(此时还没有在hash表中将线程数目+1)

线程1运行完成,发现hash表中线程只有一个,删除hash表

线程2此时才将线程数+1,但是内存已经被释放,是野指针,出错。

 

解决,所以线程2在将线程数+1时候必须将再获取一遍hash表。

 

(add by iceknife on 11 may)

关于问题2 double free的问题,经过长时间跟踪调试发现问题不在hash表,而是在生成xml文件时候的xmlSaveFormatEnc()函数的问题,此函数用到了 iconv函数,iconv被用来编码之间的转化,但是iconv句柄被打开后释放的很慢,所以不适合多线程操作,在多线程生成xml文件的时候加锁解决此问题。

你可能感兴趣的:(多线程,join,redhat,linux,xml,算法)