目录
1、listen:
2、listen、tcp三次握手
3、 发送缓冲区和接收缓冲区:
4、tcp编程启用多线程
1、listen:
执行listen会创建一个监听队列
listen(sockfd,5)
2、listen、tcp三次握手
三次握手
3、 发送缓冲区和接收缓冲区:
netstat _natp:查看缓冲区还有多少个数据,查看是送的缓冲缓冲区还没有发送,还是接收缓冲取还没有被接收
客户端发送的数据和服务器返回的数据,数量对不上是正确的,因为发送数据是从发送缓冲区进行发送,接收是从接收缓冲区进行接收,所以真正接收到的数据和发送的数据可能不相同,真正发送的,和接收到的数据也可能不相同
4、tcp编程启用多线程
如果只有一个线程,南那么只能接收一个客户端,被堵塞住了,如果先要链接多个客户端,就需要启用多个线程
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include<unistd.h>
#include<sys/socket.h>
#include<netinet/in.h>
#include <arpa/inet.h>
#include<pthread.h>
//服务器端
//利用结构体传参
struct Node_Arg
{
int c;
};
//多线程
void*fun(void*arg)
{
//传递参数c
struct Node_Arg*p=(struct Node_Arg*)arg;
int c=p->c;
while (1)
{
char buff[128]={0};
int num=recv(c,buff,127,0);
if(num<=0)
{
break;
}
printf("buff=%s\n",buff);
send(c,"ok",2,0);
}
close(c);
free(p);
printf("client close\n");
}
int main()
{
int sockfd=socket(AF_INET,SOCK_STREAM,0);
if(sockfd==-1)
{
exit(1);
}
struct sockaddr_in saddr,caddr;
memset(&saddr,0,sizeof(saddr));
saddr.sin_family=AF_INET;
saddr.sin_port=htons(6002);
saddr.sin_addr.s_addr=inet_addr("127.0.0.1");
int res=bind(sockfd,(struct sockaddr*)&saddr,sizeof(saddr));
if(res==-1)
{
printf("bind err\n");
exit(1);
}
res=listen(sockfd,5);
if(res==-1)
{
exit(1);
}
while(1)
{
socklen_t len=sizeof(caddr);
int c=accept(sockfd,(struct sockaddr*)&caddr,&len);
if(c<0)
{
continue;
}
printf("c=%d\n",c);
//创建多线程
pthread_t id;
//给结构体开辟动态内存空间
struct Node_Arg*ptr=(struct Node_Arg*)malloc(sizeof(struct Node_Arg));
ptr->c=c;
pthread_create(&id,NULL,fun,ptr);
}
}