socket中有哪些是阻塞函数?
答案:2 悬赏:70
解决时间 2021-04-08 11:27
- 提问者网友:纹身骑士
- 2021-04-07 23:53
socket中有哪些是阻塞函数?
最佳答案
- 二级知识专家网友:厭世為王
- 2021-04-08 00:08
recv
send
accept
send
accept
全部回答
- 1楼网友:何以畏孤独
- 2021-04-08 00:14
最近项目遇到一个问题,程序退出的时候资源没有正常释放。经过调试发现,原来是网络线程一直阻塞,导致一些必要的资源没有被释放,写了几个简单的测试程序调试了一下才明白,原来在linux下直接close socket的文件描述符,并不会使程序中调用的一些阻塞式的socket函数(比如 read、recvfrom 等)退出阻塞,从而导致无法正常释放资源。简化示例如下。 下面是一个简化的udp服务程序,首先创建socket对象,然后开启服务线程,将客户端发送过来的数据包回发给客户端。当用户在shell中敲入两次回车后,程序退出。#include #include #include #include #include #include #define server_port 8888 #define buffer_len 256 int g_exit = 0; void *service( void* arg ) { char buff[buffer_len]; struct sockaddr clientaddr; int socklen = sizeof(clientaddr); int recvbytes; int socketfd = *((int *)arg); printf("ok, enter service!\n"); while(!g_exit) { recvbytes = recvfrom(socketfd,buff,buffer_len,0,&clientaddr,&socklen); sendto(socketfd,buff,recvbytes,0,&clientaddr,socklen); } printf("ok, service thread exit!\n"); pthread_exit(null);; } int main(...最近项目遇到一个问题,程序退出的时候资源没有正常释放。经过调试发现,原来是网络线程一直阻塞,导致一些必要的资源没有被释放,写了几个简单的测试程序调试了一下才明白,原来在linux下直接close socket的文件描述符,并不会使程序中调用的一些阻塞式的socket函数(比如 read、recvfrom 等)退出阻塞,从而导致无法正常释放资源。简化示例如下。 下面是一个简化的udp服务程序,首先创建socket对象,然后开启服务线程,将客户端发送过来的数据包回发给客户端。当用户在shell中敲入两次回车后,程序退出。#include #include #include #include #include #include #define server_port 8888 #define buffer_len 256 int g_exit = 0; void *service( void* arg ) { char buff[buffer_len]; struct sockaddr clientaddr; int socklen = sizeof(clientaddr); int recvbytes; int socketfd = *((int *)arg); printf("ok, enter service!\n"); while(!g_exit) { recvbytes = recvfrom(socketfd,buff,buffer_len,0,&clientaddr,&socklen); sendto(socketfd,buff,recvbytes,0,&clientaddr,socklen); } printf("ok, service thread exit!\n"); pthread_exit(null);; } int main( int argc,char * argv[] ) { int fd; void *status; struct sockaddr_in serveraddr; pthread_t thr; pthread_attr_t attr; fd = socket(af_inet,sock_dgram,0); memset(&serveraddr,0,sizeof(serveraddr)); serveraddr.sin_family = af_inet; serveraddr.sin_addr.s_addr = htonl(inaddr_any); serveraddr.sin_port = htons(server_port); bind(fd,(struct sockaddr *)&serveraddr,sizeof(serveraddr)); // create service thread pthread_attr_init(&attr); pthread_attr_setdetachstate(&attr, pthread_create_joinable); if( pthread_create(&thr,&attr,service,(void *)&fd ) ) { printf("pthread_create fail!\n"); return -1; } // free attribute pthread_attr_destroy(&attr); // wait user control exit getchar(); getchar(); g_exit = 1; printf("ok, waiting for thread exit...!\n"); close(fd); // wait for thread exit pthread_join(thr, &status);printf("ok, exit main process !\n"); return 0; } 上述程序,当用户敲两次回车后,显示结果如下: 可以看到,没有打出主进程和服务线程的退出信息,无论是主进程还是服务线程都没有正常退出,由此可见,直接close socket句柄,并不能使 recvfrom 函数退出阻塞。
我要举报
如以上问答内容为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
大家都在看
推荐资讯