ioctlsocket()

本文详细介绍了ioctlsocket()函数的功能及使用方法,包括控制套接口的模式、获取套接口相关参数等内容。支持非阻塞模式设置、确定自动读入数据量等功能,并提供了常见错误代码说明。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

ioctlsocket()是控制 套接口的模式。
外文名
ioctlsocket()
含    义
控制 套接口的模式
头文件
#include <winsock.h>
性    质
函数

简述:编辑

控制 套接口的模式。
#include <winsock.h>
int PASCAL FAR ioctl socketSOCKET s, long  cmd, u_long FAR* argp);
s:一个标识套接口的描述字。
cmd:对套接口s的操作命令。
argp:指向cmd命令所带参数的 指针

注释:编辑

本函数可用于任一状态的任一 套接口。它用于获取与套接口相关的操作参数,而与具体协议或通讯子系统无关。支持下列命令:

FIONBIO:

允许或禁止 套接口s的非阻塞模式。argp指向一个无符号 长整型,如允许非阻塞模式则非零,如禁止非阻塞模式则为零。当创建一个套接口时,它就处于阻塞模式(也就是说非阻塞模式被禁止)。这与BSD套接口是一致的。WSAAsynSelect()函数将套接口自动设置为非阻塞模式。如果已对一个套接口进行了WSAAsynSelect() 操作,则任何用ioctl socket()来把套接口]重新设置成阻塞模式的试图将以WSAEINVAL失败。为了把套接口重新设置成阻塞模式,应用程序必须首先用WSAAsynSelect()调用(IEvent参数置为0)来禁止WSAAsynSelect()。

FIONREAD:

确定 套接口s自动读入的数据量。argp指向一个无符号 长整型,其中存有ioctl socket()的返回值。如果s是SOCKET_STREAM类型,则FIONREAD返回在一次 recv()中所接收的所有数据量。这通常与套接口中排队的数据总量相同。如果S是SOCK_DGRAM 型,则FIONREAD返回套接口上排队的第一个数据报大小。

SIOCATMARK:

确认是否所有的 带外数据都已被读入。这个命令仅适用于SOCK_STREAM类型的 套接口,且该套接口已被设置为可以在线接收带外数据(SO_OOBINLINE)。如无带外数据等待读入,则该操作返回TRUE真。否则的话返回FALSE假,下一个 recv()recvfrom()操作将检索“标记”前一些或所有数据。应用程序可用SIOCATMARK操作来确定是否有数据剩下。如果在“紧急”(带外)数据[前有常规数据,则按序接收这些数据(请注意,recv()和recvfrom()操作不会在一次调用中混淆常规数据与带外数]据)。argp指向一个BOOL型数,ioctl socket()在其中存入返回值。

兼容性:编辑

本函数为Berkeley 套接口函数ioctl()的一个子集。其中没有与FIOASYNC等价的命令,SIOCATMARK是套接口层次支持的唯一命令。

返回值:编辑

成功后,ioctl socket()返回0。否则的话,返回SOCKET_ERROR错误,应用程序可通过WSAGetLastError()获取相应错误代码。
WSANOTINITIALISED:在使用此 API之前应首先成功地调用WSAStartup()。
WSAENETDOWN:WINDOWS 套接口实现检测到网络子系统失效。
WSAEINVAL: cmd为非法命令,或者argp所指参数不适用于该cmd命令,或者该命令
不适用于此种类型的套接口。
WSAEINPROGRESS:一个阻塞的WINDOWS套接口调用正在运行中。
WSAENOTSOCK:描述字不是一个套接口。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值