服务器端,部分主要代码
while(1)
{
if((clientfd = accept(sockfd,(struct sockaddr*)&their_addr,&sin_size)) == -1)//接收客户端连接
{
perror("accept");
exit(1);
}
printf("accept ok\n");
send(clientfd,WEL,strlen(WEL),0);//发送问候信息
if(pthread_create(&pid[i],NULL,del_function,(void*)&clientfd))
{
printf("pthread1 err\n");
exit(1);
}
pthread_detach(pid[i]); //与主进程断开联系,这样主进程有可以接受其他的客户连接
i++;
continue;
}
下面是线程要实现的函数:
void *del_function(void *args)
{
char buf[255], *r_addr, *w_addr, temp[1024]; //定义临时存储区
int sock_sock=*(int*)args; //获得这个线程的pid
int n,maxfd;
fd_set readfd,writefd;
maxfd=sock_sock;
// printf("sock is *************** %d\n",sockfd);
int recvbytes;
while(1)
{
FD_ZERO(&writefd);
FD_ZERO(&readfd);
FD_SET(sock_sock,&writefd); //把sock_sock加入读集监控
FD_SET(sock_sock,&readfd); //把sock_sock加入写集监控
// printf("select up\n");
n=select(maxfd+1,&readfd,&writefd,NULL,NULL); //监控,直到有连接可用
// printf("select down %d\n",n);
if(n<0)
{
printf("select err\n");
exit(1);
}
else if(n==0)
{
continue;
}
else{
if(FD_ISSET(sock_sock,&readfd)) //如果可读的话
{
memset(buf,0,255);
if((recvbytes = recv(sock_sock,buf,255,0)) <= 0)
{
perror("recv1");
close(clientfd);
raise(SIGKILL);
exit(1);
}
w_addr = shmat(shmid, 0, 0);
memset(w_addr, '\0', 1024);
strncpy(w_addr, buf, 1024);
// printf("%s\n",buf);
}
// sleep(1);
if(FD_ISSET(sock_sock,&writefd)) //如果可写的话
{
r_addr = shmat(shmid, 0, 0);
if(strcmp(temp,r_addr) != 0)
{
strcpy(temp,r_addr);
if(send(sock_sock,r_addr,strlen(r_addr),0) == -1)
{
perror("send");
}
memset(r_addr, '\0', 1024);
strcpy(r_addr,temp);
}
}
}
sleep(1); //这里要加一个sleep();如果不加的话,可能(只是可能会出现段错误,这应该是运行的速度过快,导致后面的访问失败)
}
}