本章将介绍Winsock基本框架
Winsock 是用来网络编程的标准应用程序接口(API).
Winsock2 中的函数相对Winsock1用前缀WSA来区分.
特殊:Winsock1.1规范有:WSAStartup();WSACleanup();WSARecvEx();WSAGetLastError().
Winsock使用环境搭建
Winsock1 | Winsock2 | extention | |
---|---|---|---|
头文件 | winsock1.h | winsock2.h | mswsock.h |
链接库 | wsock32.lib | ws2_32.lib | wsock.dll |
链接库 | wsock32.lib | ws2_32.lib | wsock.dll |
其中 mswsock.h 用来编写高效网络程序
初始化Winsock
int WSAStartup(
WORD wVersionRequested, //指定用加载的Winsock库版本
LPWSADATA lpWSAData //WSAStartup()启用时填充库信息到该数据结构中,数据结构见下
);
WSADATA结构体
typedef struct WSADATA
{
WORD wVersion; //使用的Winsock版本,高字节主版本,低字节副版本
WORD wHighVersion; //Winsock library可使用的最高版本,高字节主版本,低字节副版本
char szDescription[WSADESCRIPTION_LEN+1]; //由Winsock专门实现填充,实际不使用
char szSystemStatus[WSASYS_STATUS_LEN+1]; //由Winsock专门实现填充,实际不使用
unsigned short iMaxSockets; //最高并发sockets数量,有物理环境决定
unsigned short iMaxUdpDg; //最大数据包大小
char FAR * lpVendorInfo; //开发商信息,在windows平台不使用
}WSADATA,*LPWSADATA;
通过MAKEWORD(x,y)宏来设置版本号
MAKEWORD(
x, //高字节,副版本号
y //低字节,主版本号
);
不同平台下的Winsock版本
Platform | Winsock Version |
---|---|
Windows 95 | 1.1(2.2) |
Windows 98 | 2.2 |
Windows Me | 2.2 |
Windows NT 4.0 | 2.2 |
Windows 2000 | 2.2 |
Windows XP | 2.2 |
Windows CE | 1.1 |
通常根据适用平台来决定用Winsock的哪个版本来进行开发.
Winsock退出
WSACleanup()(void);
调用WSACleanup()失败并不会产生坏处因为你的操作系统会自动帮你释放资源,但是这样会违反Winsock规范.
每一个WSAStartup()都对应要调用一个WSACleanup()来退出.
错误发生后调用函数时会返回一个特定错误值,通过WSAGetLastError()来获取错误序号.
这些错误值宏定义在<winsock.h>和<winsock2.h>中,其中<winsock2.h>扩展了前者.
运行环境:VS2010,需要链接库ws2_32.lib
最基本的Winsock框架
#include <winsock2.h>
#include <iostream>
using namespace std;
int main(void)
{
WSADATA wsaData;
if(int Ret=WSAStartup(MAKEWORD(2,2),&wsaData)!=0) {
cout<<"WSAStartup failed with error "<<Ret<<endl;
}
else{
cout<<"WSAStartup success."<<endl;
}
if(WSACleanup()==SOCKET_ERROR){
cout<<"WSACleanup failed with error "<<WSAGetLastError()<<endl;
}
else{
cout<<"WSACleanup success."<<endl;
}
return 0;
}