代码如下:
while(1)
{
/*调用accept函数,等待客服端的链接 */
if((client_fd=accept(sockfd,(struct sockaddr *)&client_sockaddr,&sin_size))==-1)
{
perror("accept");
exit(1);
}
connect_time++;
printf("connect_time is %d\n",connect_time);
if(!fork())
{
for(;;)
{
/*创建两个线程*/
ret=pthread_create(&toDsp,NULL,(void *)writeToDsp, NULL);
if(ret!=0)
perror("pthread cread1");
ret=pthread_create(&toNet,NULL,(void *)writeToNet, NULL);
if(ret!=0)
perror("pthread cread2");
pthread_join(toDsp,NULL);
pthread_join(toNet,NULL);
printf("resource release!\n"); //debug-2010.12.06
}
close(client_fd);
}
}
问题在于父进程新建子进程后,返回到while循环头等待accept。子进程创建两个pthread,两个pthread轮流取数据和传数据,通过sem控制,循环运行不会退出。
如果来了connect,父进程accept后,会重新新建子进程,子进程再创建pthread进行数据传输,程序是能正常运行的,但速率会变慢。
此时之前的子进程是如何退出的,是否释放资源??
不知道说清楚没,希望高人指点。谢谢
考乌特莫克 于 2011-01-08 01:02:13发表:
我觉得问题可能出在这里:
pthread_join(toDsp,NULL);
pthread_join(toNet,NULL);
函数调用pthread_join解决的是线程资源释放的问题,但是这个时候每次调用子进程都是要等待线程结束才能继续运行的。这个函数是一个线程阻塞的函数,调用它的函数将一直等待到被等待的线程结束为止,当函数返回时,被等待线程的资源被收回。
建议使用设置线程属性的方法来实现资源回收:PTHREAD_CREATE_DETACHED
165671242 于 2010-12-10 09:11:59发表:
来人啊。。o(?□?)o。。。。