UINT port = 2000; char szIP[20] = "127.0.0.1"; WSADATA wsaData; //初始化Socket库 WSAStartup(MAKEWORD(2,0),&wsaData); //我们使用的WinSock版本 MAKEWORD(2,0) SOCKET sListen = socket(AF_INET,SOCK_STREAM,IPPROTO_TCP); int iAddrSize; //当创建了一个套接字后,必须把套接字与你需要进行通讯的地址建立联系 SOCKADDR_IN Local, client; //结构体 Local.sin_family=AF_INET; //告诉WinSock使用的是IP地址族 Local.sin_port=htons(port);//设置电线连接服务器端的端口 Local.sin_addr.S_un.S_addr=inet_addr(szIP); int rbind = bind(sListen,(struct sockaddr*)&Local,sizeof(Local)); if(SOCKET_ERROR == rbind) { MessageBox(NULL,TEXT("绑定错误"),"",MB_OK); } /* int err = GetLastError(); TCHAR iError[20]; itoa(err,iError,sizeof(iError)/sizeof(TCHAR)); MessageBox(hwnd,iError,"",MB_ICONERROR); */ int rlisten = listen(sListen,5); if(SOCKET_ERROR == rlisten) { MessageBox(NULL,TEXT("监听错误"),"",MB_OK); } /* int err = GetLastError(); TCHAR iError[20]; itoa(err,iError,sizeof(iError)/sizeof(TCHAR)); MessageBox(hwnd,iError,"",MB_ICONERROR); */ SOCKET sClient = accept(sListen,(struct sockaddr*)&client,&iAddrSize); if(sClient == INVALID_SOCKET) { MessageBox(NULL,TEXT("接收错误"),"",MB_OK); } /* int err = GetLastError(); TCHAR iError[20]; itoa(err,iError,sizeof(iError)/sizeof(TCHAR)); MessageBox(hwnd,iError,"",MB_ICONERROR); */ TCHAR buff[256]; ZeroMemory(buff,sizeof(buff)); int rrecv = recv(sClient,buff,sizeof(buff),0); MessageBox(NULL,buff,"",0); if(SOCKET_ERROR == rrecv) { MessageBox(NULL,TEXT("失败"),"",MB_OK); } else { MessageBox(NULL,TEXT("成功"),"",MB_OK); MessageBox(NULL,buff,"",0); } WSACleanup(); closesocket(sClient); closesocket(sListen); }
一触发函数就直接报了“接受错误”。我尝试把系统的错误代码打出来,从bind开始,返回0;listen 返回0,说明都成功了,再是accept后返回了 错误代码 10014,
后来去网上一找,找到这样的博客,这里引用下:
SOCKET accept(
__in SOCKET s,
__out struct sockaddr *addr,
__inout int *addrlen
);
第一个参数就是套接字描述符,第二个参数是,接受客户端基本信息的结构体,第三参数就火了,是准备接受结构体的大小,
上面的程序 int iAddrSize,传进去的时候只是把未知的iAddrSize的地址传进去,要传进去的应该是接收这些信息的基本大小啊,
所以 得加 iAddrSize = sizeof(SOCKADDR)。
这样程序就会阻塞在accept的时候。
先前一直都想把程序弄成非阻塞的,也绞尽脑汁。现在想让它阻塞都困难。这着实说明了C语言的强大·····