您的位置:首页 > 其它

套接字函数详细介绍

2011-08-09 18:08 471 查看
套接字函数介绍

套接字函数通常封装在Ws2_32.dll动态连接库中,头文件是winsock2.h,因此用户需要引用头文件和链接库

#include “winsock.h” //引用头文件

#pragma comment(lib,”ws2_32.lib”) //链接库文件

此外,使用套接库函数前需要初始化套接字,使用函数WSAStartup()实现

例如: WSADATA wsd; //定义WSADATA对象

WSAStartup(MAKEWORD(2,2),&wsd); //初始化套接字

下面介绍一些套接字函数





1:WSAStartup函数:用于初始化动态连接库,而且不可或缺

int WSAStartup(WORD wVersionRequested,LPWSADATA lpWDADATA)

//用法参见前面几行代码





2:socket函数:用于创建一个套接字

SOCKET socket(int af, int type, int protocol)

Af:表示一个地址家族,通常是AF_INET

type:表示套接字类型。SOCK_STREAM:创建面向连接的流式套接字

SOCK_DGRAM:表示创建面向无连接的数据报套接字,SOCK_RAW:表示创原始套接

protocol:表示所用的协议,不指定时可以设置为0

函数的返回值是创建的套接字句柄





3:bind函数:用于将套接字绑定到指定的端口和地址上

int bind(SOCKET s,const struct sockadddr FAR * name, int namelen)

s:表示套接字标志

name:是一个sockaddr结构指针,包含了端口和地址

namelen:确定name缓冲区长度

返回值:成功返回0;失败返回SOCKET_ERROR





4: listen函数:用于将套接字设置为监听模式。对于流式套接字必须是该模式

Int listen(SOCKET s, int backlog)

Backlog: 表示等待连接的最大队列长度





5:accept函数:用于接收客户端的链接

SOCKET accept(SOCKET s, struct sockaddr FAR *addr, int FAR * addlen)

S:一个套接字标志,应该处于监听状态

addr:包含一组客户端的端口和地址信息

addlen:用于接收参数addr的长度

返回值:一个新的套接字,它对应于已经接受的客户端连接,对于该客户端的所有后

续操作,都应该使用这个新的套接字





6:closesocket函数:关闭套接字

int closesocket(SOCKET s);





7:connect函数:用于发送一个连续请求

int connect(SOCKET s, const struct sockaddr FAR * name, int namelen)

name:表示套接字想链接的主机地址和端口号

namelen:表示缓冲区长度

成功返回0,走则为SOCKET_ERROR



8:htons函数:将一个16位的无符号短整型数据由主机排列方式转换成网络排列方式

u_short htons(u_short hostshort)

hostshort:表示一个主机排列方式的无符号整形数据

返回值是一个网络排序的无符号短整型数据





9:htonl函数:表示将一个主机排列的长整型数据有主机排列转换成网络排列

u_long htonl(u_long hostlong);



10:inet_addr函数:将一个由字符串表示的地址转换成32位的无符号长整型数据

Unsigned long inet_addr(const char FAR * cp);

cp:表示一个IP地址的字符串

返回一个32位无符号长整数



11:recv函数:用于从面向连接的套接字中接收数据

int recv(SOCKET s, char FAR *buf,int len, int flags)

buf:接收数据的缓冲区

len:buf的长度

flags表示函数的调用方式 MSG_PEEK:表示查看传来的数据

MSG_OOB表示用来处理外带数据



12;send函数:用于在面向连接方式的套接字间发送数据

int send(SOCKET s, const char FAR * buf, int len, int flags)

buf要发送数据缓冲区的大小

flags函数的调用方式



13:select函数:用来检查一个或多个套接字是否处于可读、可写或错误状态

Int select(int nfds,fd_set FAR *readfds, fd_set FAR *writefds,fd_set FAR * exceptfds, const struct timeval FAR * timeout)

nfds:无实际意义

readfds表示一组可读套接字

writefds表示一组可写套接字

exceptfds表示一组被检查有错误的套接字

timeout表示函数的等待时间



14:WSACleanup函数:用于释放从Ws2_32.dll动态连接库初始化分配的资源

Int WSACleanup(void)



15:WSAAsyncSelect函数,用于将网络中发生的事情关联到窗口的某个消息中

Int WSAAsyncSelect(SOCKET s,HWND hwnd,unsigned int wMsg,long lEvent)

Hwnd:表示接收消息的窗口句柄

wMsg表示窗口接受来自套接字中的消息

lEvent表示网络中发生的事



16:ioctlsocket函数:用于设置套接字的I/O模式

Int ioctlsocket(SOCKET s, long cmd, u_long FAR * argp)

Cmd:操作命令:如果是FIONBIO,argp为0时,表示禁止非阻塞模式,argp为非0时表示设置是非阻塞模式。如果是FIONREAD表示从套接字中可以读取的数据量。SIOCATMARK 表示是否所有的外带数据都已被写入。

argp表示命令参数



17WSAGetOverlappedResult函数,用于获取重叠I/O操作完成时的结果

BOOL WSAGetOverlappedResult(SOCKET s, LPWSAOVERLAPPED lpOverlapped, LPDWORD lpcbTransfer,BOOL fWait,LPDWORD lpdwFlags)

S:表示套接字

lpOverlapped:标志一个I/O重叠操作的结构指针

lpcbTransfer:表示本次操作实际接受或发送的字节数

fWait: TRUE表示除非I/O操作完成,否则函数不会返回,FALSE表示如果函数进行中,则函数立即返回FALSE

lpdwFlags:表示一组标记,通常来自于WSARecv函数的lpFlags参数



18CreateIoCompletionPort函数,表示用于创建完成端口对象

HANDLE CreareIoCompletionPort(HANDLE FileHandle, HANDLE ExitingCompetionPort,ULONG_PTR CompletionKey,DWORD NumberOfConcurrentThread);

FileHandle:表示完成端口的关联对象。如果是创建完成端口,参数为INVALID_HANDLE_VALUE;

ExitingCompetionPort:表示关联FileHandle对象的完成端口,如果创建完成端口,参数是NULL

CompletionKey:表示端口的完成键值,用户指定一个自定义的结构指针,用于表示关联完成端口的附加数据

NumberOfConcurrentThread:表示允许同时运行的用户线程的最大数量,通常设置为0,表示系统根据CPU数量确定
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: