ioctlsocket()

原创 2013年12月05日 16:03:16

1简述:

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

2注释:

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

FIONBIO:

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

FIONREAD:

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

SIOCATMARK:

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

3兼容性:

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

4返回值:

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

5参见:

socket(), setsockopt(), getsockopt(), WSAAsyncSelect().
该命令
不适用于此种类型的套接口。
WSAEINPROGRESS:一个阻塞的WINDOWS套接口调用正在运行中。
WSAENOTSOCK:描述字不是一个套接口。

6使用方法

下面这段代码演示了ioctlsocket函数的使用方式
C++代码
#include <winsock2.h>
#include <stdio.h>
#pragma comment(lib, "Ws2_32.lib")
void main(){
//-------------------------
// Initialize Winsock
WSADATA wsaData;
int iResult;
u_long iMode = 0;
iResult = WSAStartup(MAKEWORD(2,2), &wsaData);
if (iResult != NO_ERROR)
printf("Error at WSAStartup()\n");
//-------------------------
// Create a SOCKET object.
SOCKET m_socket;
m_socket = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP);
if (m_socket == INVALID_SOCKET)
{ printf("Error at socket(): %ld\n", WSAGetLastError());
WSACleanup(); return;
}
//-------------------------[1]
// Set the socket I/O mode: In this case FIONBIO
// enables or disables the blocking mode for the
// socket based on the numerical value of iMode.
// If iMode = 0, blocking is enabled;
// If iMode != 0, non-blocking mode is enabled.
iResult = ioctlsocket(m_socket, FIONBIO, &iMode);
if (iResult != NO_ERROR)
printf("ioctlsocket failed with error: %ld\n", iResult);
}

ioctlsocket函数全面解析

说明:这篇博客算不得是原创,是我那里切一块这里剪一块凑来的。 先看看MSDN标准解释 int ioctlsocket( SOCKET s, long cmd, u_long FAR *argp...
  • liujiayu2
  • liujiayu2
  • 2015年07月29日 14:24
  • 8696

ioctlsocket函数说明

http://baike.baidu.com/view/569202.htm?fr=aladdin
  • zhubosa
  • zhubosa
  • 2014年07月24日 15:02
  • 1788

ioctl在socket中的一些用法及示例

http://blog.chinaunix.net/uid-20692625-id-3172833.html ioctl在socket中的一些用法及示例 函数 : ioctl(int fd, ...
  • chengfangang
  • chengfangang
  • 2013年03月01日 15:36
  • 1428

Select模型与ioctlsocket的使用方法

Select模型与ioctlsocket的使用方法   2011-03-29 11:38:26|  分类:软件开发C++ |  标签:ioctlsocket  socket  阻塞  select ...
  • FENGQIYUNRAN
  • FENGQIYUNRAN
  • 2015年04月21日 11:30
  • 605

Select() 与 ioctlsocket()

Select() 与 ioctlsocket() Winsock 的I/O操作:  1、 两种I/O模式      * 阻塞模式:执行I/O操作完成前会一直进行等待,不会将控...
  • lin0501040115
  • lin0501040115
  • 2012年08月16日 09:51
  • 531

getsockopt() setsockopt() ioctlsocket() fcntl() 用法

getsockopt() 简述:    获取一个套接口选项。    #include       int PASCAL FAR getsockopt( SOCKET s, int le...
  • star19830909
  • star19830909
  • 2017年07月21日 09:43
  • 146

ioctlsocket() 用法

ioctlsocket() 用法 ioctlsocket()  简述:   控制套接口的模式。   #include   int PASCAL FAR ioctlsocket( SOCK...
  • zhuimengzh
  • zhuimengzh
  • 2012年09月28日 17:41
  • 2631

ioctlsocket()详解

转载自:http://zjqzy03080312.blog.163.com/blog/static/185742807201221393357799/ 简述:   控制套接口的模式。   #in...
  • kath_y
  • kath_y
  • 2013年04月14日 14:15
  • 782

ioctlsocket函数全面解析

说明:这篇博客算不得是原创,是我那里切一块这里剪一块凑来的。 先看看MSDN标准解释 int ioctlsocket( SOCKET s, long cmd, u_long FAR *argp...
  • liujiayu2
  • liujiayu2
  • 2015年07月29日 14:24
  • 8696

SOCKET函数SETSOCKOPT IOCTLSOCKET 设置

SETSOCKOPT IOCTLSOCKET 设置非阻塞SOCKET函数 1,ioctlsocket() #include   This function contr...
  • u010353644
  • u010353644
  • 2014年01月03日 11:42
  • 226
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:ioctlsocket()
举报原因:
原因补充:

(最多只允许输入30个字)