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语言的强大·····