windows套接字相关函数
作者:vpoet
mail:vpoet_sir@163.com

我们学习TCP/IP协议无非是利用这些协议进行通信开发,然而如果让我们自己来直接根据协议规则和协议格式来进行网络开发无疑
是一件十分痛苦的事情,显然为了减轻程序员的开发负担,windows提供给我们一套网络开发的API,这个API族就叫做套接字库。
但是套接字和TCP/IP协议到底是什么关系呢。
我们暂且可以这样理解,如图:


那么OK,理解不了我们也暂且这样理解吧。接下来我们讲讲使用套接字编程主要用到API




1:socket
MSDN这样描述:

The Windows Sockets socket function creates a socket that is bound to a specific service provider.

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

Parameters

af
[in] Address family specification.
type
[in] Type specification for the new socket.

The following are the only two type specifications supported for Windows Sockets 1.1:

Type Explanation
SOCK_STREAM Provides sequenced, reliable, two-way, connection-based byte streams with an OOB data transmission mechanism. Uses TCP for the Internet address family.
SOCK_DGRAM Supports datagrams, which are connectionless, unreliable buffers of a fixed (typically small) maximum length. Uses UDP for the Internet address family.

In Windows Sockets 2, many new socket types will be introduced and no longer need to be specified, since an application can dynamically discover the attributes of each available transport protocol through the
WSAEnumProtocols function. Socket type definitions appear in Winsock2.h, which will be periodically updated as new socket types, address families, and protocols are defined.

protocol
[in] Protocol to be used with the socket that is specific to the indicated address family. 


该函数创建一个套接字,参数af为协议族类型AF_INET为TCP/IP协议族
type为套接字类型,有两种类似SOCK_STREAM为使用TCP进行通信 SOCK_STREAM为使用UDP进行通信
protocol可以为IPPROTO_TCP或IPPROTO_IP,此参数英语type保存一致
举例:SOCKET S;
 S=socket(AF_INET,SOCK_STREAM,IPPOTO_TCP)表示使用TCP协议进行通信






2.bind
顾名思义即绑定,用过套接字编程的都知道,当我们编写服务端程序的时候需要使用该函数
MSDN这样描述:

The Windows Sockets bind function associates a local address with a socket.

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

Parameters

s
[in] Descriptor identifying an unbound socket.
name
[in] Address to assign to the socket from the SOCKADDR structure.
namelen
[in] Length of the value in the name parameter.

Return Values

If no error occurs, bind returns zero. Otherwise, it returns SOCKET_ERROR, and a specific error code can be retrieved by calling WSAGetLastError.

该函数将一个本地的地址绑定到一个套接字上,如果绑定不错位,将返回0,否则将返回SOCKET_ERROR
参数s为需要绑定的套接字
参数*name为一个常量sockaddr结构,但是一般情况下我们都使用sockaddr_in结构
其结构定义如下:
struct
sockaddr_in {
  short int sin_family; /* Address family */
  unsigned short int sin_port; /* Port number */
  struct
sin_addr sin_addr; /* Internet address */
  unsigned char sin_zero[8]; /* Same size as struct sockaddr */
  };
  sin_family:指代协议族,在socket编程中只能是AF_INET
  sin_port:存储端口号(使用网络字节顺序)
  sin_addr:存储IP地址,使用in_addr这个数据结构
  sin_zero:是为了让sockaddr与sockaddr_in两个数据结构保持大小相同而保留的空字节。
其中sin_addr定义
typedef
struct in_addr {
  union {
  struct{ unsigned char s_b1,s_b2, s_b3,s_b4;} S_un_b;
  struct{ unsigned short s_w1, s_w2;} S_un_w;
  unsigned long S_addr;
  } S_un;
  } IN_ADDR;

一般我们这样用
addrs.sin_addr.S_addr=inet_addr("192.168.1.110")
函数inet_addr可以把字符串直接转换成in_addr类型
也可以使用inet_ntoa()将in_addr类型转换为字符串类型
参数namelen即为name的长度 即sizeof(name)
举个典型的例子:
SOCKET s;
s=socket(AF_INET,SOCK_STREAM,IPPOTO_TCP);
sockaddr_in addrbindto;
addrbindto.sin_family=AF_INET;
addrbindto.port=htons(8001)
htons是将u_short类型转换为网络字节序,htonl是将u_long类型转换为网络字节序
addrbindto.sin_addr_S_addr=inet_addr("192.168.1.110")
bind(s,(
const struct sockaddr
)&addrbindto,sizeof(addrbindto))


3.listen

The Windows Sockets listen function places a socket a state where it is listening for an incoming connection.

int listen(
SOCKET
s,
int
backlog
);
 

Parameters

s
[in] Descriptor identifying a bound, unconnected socket.
backlog
[in] Maximum length of the queue of pending connections. If set to SOMAXCONN, the underlying service provider responsible for socket s will set the backlog to a maximum reasonable value. There is no standard provision to obtain the actual backlog value.

Return Values

If no error occurs, listen returns zero. Otherwise, a value of SOCKET_ERROR is returned, and a specific error code can be retrieved by calling WSAGetLastError.

该函数在指定的套接字上监听连接请求,参数s为监听的套接字,backlog表示表示允许的最大连接数

举例:
listen(s,5);




4.connect

The Windows Sockets connect function establishes a connection to a specified socket.

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

Parameters

s
[in] Descriptor identifying an unconnected socket.
name
[in] Name of the socket to which the connection should be established.
namelen
[in] Length of name

该函数对一个指定的套接字建立连接

参数s为想要建立连接的套接字
name为sockaddr类型的指针
namelen即为sizeof(name)

举例:
SOCKET s;
sockaddr_in conaddr;
s=socket(AF_INET,SOCK_STREAM,IPPOTO_TCP);
conaddr.sin_family=AF_INET;
conaddr.port=htons(8001) htons是将u_short类型转换为网络字节序,htonl是将u_long类型转换为网络字节序
conaddr.sin_addr_S_addr=inet_addr("192.168.1.110")
connect(s,(const struct sockaddr)&conaddr,sizeof(conaddr))



5.send

The Windows Sockets send function sends data on a connected socket.

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

Parameters

s
[in] Descriptor identifying a connected socket.
buf
[in] Buffer containing the data to be transmitted.
len
[in] Length of the data in buf.
flags
[in] Indicator specifying the way in which the call is made. 


该函数用于向已连接的套接字发送数据
参数s为一个连接到的套接字
参数buf为发送数据的缓存
参数len为发送缓存数据的长度

举例:
char buf[20]="hello123";
send(s,(const char *)buf,sizeof(buf))



5.recv

The Windows Sockets recv function receives data from a connected socket.

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

Parameters

s
[in] Descriptor identifying a connected socket.
buf
[out] Buffer for the incoming data.
len
[in] Length of buf

该函数为接受函数:
参数与send类型,不在赘述



6. recvfrom,sendto
这两个函数功能与send与recv类似,只是它们用于UDP通信中



OK,主要函数先介绍到这儿,等下篇博文我们亲自动手来写一个基于TCP的简单CS通信小Demo

windows套接字相关函数的更多相关文章

  1. 缺少网络连接需要的Windows套接字注册表项(浏览器无法连网)

      缺少网络连接需要的Windows套接字注册表项(浏览器无法连网) CreateTime--2018年4月25日14:17:42 Author:Marydon 1.异常信息 此计算机上缺少一个或多个 ...

  2. 基于Windows的套接字相关函数及示例

    链接ws2_32.lib库 头文件#include <winsock2.h> int WSAStartup(WORD wVersionRequested,LPWSADATA lpWSADa ...

  3. Windows套接字Socket函数

    1.使用套接字函数之前,先要加载套接字函数库: #include "Winsock2.h" #pragma comment(lib,"Ws2_32.lib") ...

  4. windows套接字阻塞模式编程实例

    一.阻塞模式套接字服务端和客户端的运行流程如下: 1.1 服务器运行过程如下: 1.服务器启动后,等待客户端的连接请求.2.当收到客户端的请求后,在界面上显示该客户端的IP地址和端口,以及“Hello ...

  5. Windows进程间通讯(IPC)----套接字

    Windows套接字 Windows套接字即socket,通过socket可以实现在不同的进程间通信,甚至这两个进程可以不在同一个计算机中. Winsock使用步骤 服务端 socket初始化 创建套 ...

  6. 套接字编程(VC_Win32)

    简介(源于维基) Berkeley套接字(也作BSD套接字应用程序接口)刚开始是4.2BSD Unix操作系统(于1983发布)的一套应用程序接口.然而,由于AT&T的专利保护着UNIX,所以 ...

  7. VC远控(一)界面设计及套接字连接测试

    首先创建一个MFC项目. 选择基于对话框: 勾选Windows套接字 依次拉上各种不同的控件: Edit Control.Button.Tree.Static Text.List.Progress C ...

  8. CAsyncSocket create创建套接字失败

    解决方法: 在继承CAsyncSocket 类的子类的构造函数中加入以下代码: if (!AfxSocketInit()) AfxMessageBox(IDP_SOCKETS_INIT_FAILED) ...

  9. C项目实践--网络协议和套接字编程

    1.TCP/IP协议 TCP/IP协议是一组包括TCP协议和IP协议,UDP(User Datagram Protocol)协议,ICMP(Internet Control Message Proto ...

随机推荐

  1. uva10245-The Closest Pair Problem(平面上的点分治)

    解析:平面上的点分治,先递归得到左右子区间的最小值d,再处理改区间,肯定不会考虑哪些距离已经大于d的点对,对y坐标归并排序,然后从小到大开始枚举更新d,对于某个点,x轴方向只用考虑[x-d,x+d]( ...

  2. Java宝典(三)

    --说说ArrayList,Vector,LinkedList的存储性能和特性. --ArrayList和Vector都是使用数组方式存储数据,此数组元素数大于实际存储的数据以便增加和插入元素,他们都 ...

  3. 【LeetCode练习题】Valid Palindrome

    Valid Palindrome Given a string, determine if it is a palindrome, considering only alphanumeric char ...

  4. PC-CSS-默认字体样式

    字体样式:Arial:字体大小:12px;行高:1.5倍:

  5. 【Struts2】新建一个Struts2工程,初步体验MVC

    实现目标 地址栏输入http://localhost:88/Struts2HelloWorld/helloworld.jsp 输入用户名,交由http://localhost:88/Struts2He ...

  6. IOS中的各种Picker

    简述 在应用的一些设置中经常要用到一些Picker来快速帮助用户选定取值,一般会用到的有UIDatePicker,UIPickerView以及UIImagePickerController. 初始界面 ...

  7. C#基础学习心得(一)

    类的成员 数据成员:字段,常量(const) 函数成员:方法,属性,索引器,构造函数,析构函数,事件 类的声明 实例成员:对象相关性,不同于同一类的其他实例 静态成员:常量,static修饰的字段,方 ...

  8. 移动前端开发之 viewport 的深入理解

    移动设备上进行网页的重构或开发,首先得搞明白的就是移动设备上的viewport了,只有明白了viewport的概念以及弄清楚了跟viewport有关的meta标签的使用,才能更好地让我们的网页适配或响 ...

  9. 触控(Touch)

    1 使用触控实现一个简易的画板 1.1 问题 触控(Touch)是一个UITouch类型的对象,当用户触摸了屏幕上的视图时自动被创建,通常使用触控实现绘图.涂鸦.手写等功能.本案例使用触控实现一个简易 ...

  10. zoj Grouping(强连通+缩点+关键路径)

    题意: 给你N个人,M条年龄大小的关系,现在打算把这些人分成不同的集合,使得每个集合的任意两个人之间的年龄是不可比的.问你最小的集合数是多少? 分析: 首先,假设有一个环,那么这个环中的任意两个点之间 ...