2.2 Windows平台下实现以及验证
Win下的实现方式基本类似,只要稍加了解socket函数的返回值类型就行
2.2.1 Windows操作系统的socket函数
Win下socket和Linux下名字一样,只有返回值不同,这里再次给出 Win下 socket函数的声明
#include <winsock2.h>
SOCKET socket(int af, int type, int protocol);
->成功时返回socket句柄,失败返回 INVALID_SOCKET.
返回值类型就是 int 只不过考虑到扩展性,定义为 SOCKET数据类型
同理,INVALID_SOCKET 其实也是 int 类型(-1)也是为了扩展性,微软在Win下起了这个名字
2.2.2 基于Windows下的TCP套接字示例
与Linux下的示例差不多,服务器端没啥变化,客户端改变read函数调用方式
hello_server_win.c -> tcp_server_win.c :无变化
hello_client_win.c -> tcp_client_win.c :更改read函数调用方式
tcp_client_win.c
#include <stdio.h>
#include <stdlib.h>
#include <winsock2.h>
void ErrorHandling(char* message);
int main(int argc, char* argv[])
{
WSADATA wsaData;
SOCKET hSocket;
SOCKADDR_IN servAddr;
char message[30];
int strlen = 0;
int idx = 0, readLen = 0;
if(argc != 3){
printf("Usage %s <IP> <port>\n", argv[0]);
exit(1);
}
if(WSAStartup(MAKEWORD(2, 2), &wsaData) != 0){ //初始化Winsock库
ErrorHandling("WSAStartup() error !");
}
hSocket = socket(PF_INET, SOCK_STREAM, 0); //创建套接字
if(hSocket == INVALID_SOCKET){
ErrorHandling("socket() error!");
}
memset(&servAddr, 0, sizeof(servAddr));
servAddr.sin_family = AF_INET;
servAddr.sin_addr.s_addr = inet_addr(argv[1]);
servAddr.sin_port = htons(atoi(argv[2]));
//通过此套接字向服务器端发出连接请求
if(connect(hSocket, (SOCKADDR*)&servAddr,sizeof(servAddr)) == SOCKET_ERROR){
ErrorHandling ("connect() error");
}
//用recv函数接受服务器发来的数据
while(readLen = recv(hSocket,&message[idx++],1,0)){
if(strlen == -1){
ErrorHandling("read() error!");
}
strlen += readLen;
}
printf("Message from server: %s \n",message );
printf("Function read call count: %d\n",strlen );
closesocket(hSocket);
WSACleanup(); //程序终止前,注销初始化的套接字库
return 0;
}
void ErrorHandling(char* message)
{
fputs(message,stderr);
fputc('\n',stderr);
exit(1);
}