(转)关于 WSAData 结构体
WinSock 编程的第一步就是加载 ws2_32.dll,然后调用 WSAStartup() 函数进行初始化,并指明要使用的版本号。
WSAStartup() 函数执行成功后,会将与 ws2_32.dll 有关的信息写入 WSAData 结构体变量。WSAData 的定义如下:
typedef struct WSAData { WORD wVersion; //ws2_32.dll 建议我们使用的版本号 WORD wHighVersion; //ws2_32.dll 支持的最高版本号 //一个以 null 结尾的字符串,用来说明 ws2_32.dll 的实现以及厂商信息 char szDescription[WSADESCRIPTION_LEN+1]; //一个以 null 结尾的字符串,用来说明 ws2_32.dll 的状态以及配置信息 char szSystemStatus[WSASYS_STATUS_LEN+1]; unsigned short iMaxSockets; //2.0以后不再使用 unsigned short iMaxUdpDg; //2.0以后不再使用 char FAR *lpVendorInfo; //2.0以后不再使用 } WSADATA, *LPWSADATA;
最后3个成员已弃之不用,szDescription 和 szSystemStatus 包含的信息基本没有实用价值,读者只需关注前两个成员即可。请看下面的代码:
#include <stdio.h> #include <winsock2.h> #pragma comment(lib, "ws2_32.lib") int main() { WSADATA wsaData; WSAStartup(MAKEWORD(2, 2), &wsaData); printf("wVersion: %d.%d\n", LOBYTE(wsaData.wVersion), HIBYTE(wsaData.wVersion)); printf("wHighVersion: %d.%d\n", LOBYTE(wsaData.wHighVersion), HIBYTE(wsaData.wHighVersion)); printf("szDescription: %s\n", wsaData.szDescription); printf("szSystemStatus: %s\n", wsaData.szSystemStatus); return 0; }
运行结果:

ws2_32.dll 支持的最高版本为 2.2,建议使用的版本也是 2.2。
浙公网安备 33010602011771号