SOCKET编程

SOCKET的API

1、 int socket(int domain, int type, int protocol);
domain:协议域,常用的协议族有,AF_INET、AF_INET6、AF_LOCAL(或称AF_UNIX,Unix域socket)、AF_ROUTE等等。协议族决定了socket的地址类型,在通信中必须采用对应的地址,如AF_INET决定了要用ipv4地址(32位的)与端口号(16位的)的组合、AF_UNIX决定了要用一个绝对路径名作为地址。
type:指定socket类型。常用的socket类型有,SOCK_STREAM、SOCK_DGRAM、
SOCK_RAW、SOCK_PACKET、SOCK_SEQPACKET等等。
流格式套接字(SOCK_STREAM):面向有连接的套接字;
数据报格式套接字(SOCK_DGRAM):面向无连接的套接字
SOCK_PACKET:内核将不对网络数据进行处理而直接交给用户,数据直接从网卡的协议栈交给用户
protocol:指定协议。常用的协议有,IPPROTO_TCP、IPPROTO_UDP、IPPROTO_SCTP、IPPROTO_TIPC等,它们分别对应TCP传输协议、UDP传输协议、STCP传输协议、TIPC传输协议

注意:并不是上面的type和protocol可以随意组合的,如SOCK_STREAM不可以跟IPPROTO_UDP组合。当protocol为0时,会自动选择type类型对应的默认协议。
2、int bind(int sockfd, const struct sockaddr *addr, socklen_t addrlen)
• sockfd:即socket描述字,它是通过socket()函数创建了,唯一标识一个socket。bind()函数就是将给这个描述字绑定一个名字。
• addr:一个const struct sockaddr 指针,指向要绑定给sockfd的协议地址。这个地址结构根据地址创建socket时的地址协议族的不同而不同,如ipv4对应的是:
struct sockaddr_in
{
sa_family_t sin_family; /* address family: AF_INET /
in_port_t in_port; /
port in network byte order /
struct in_addr sin_addr; /
internet address /
};
struct in_addr {
uint32_t s_addr; /
address in network byte order */
};
• addrlen:对应的是地址的长度。
3、int listen(int sockfd, int backlog);
backlog:相应socket可以排队的最大连接个数
4、int connect(int sockfd, const struct sockaddr *addr, socklen_t addrlen);//客户端
• addr:为服务器的socket地址,
• addrlen:为socket地址的长度。
5、int accept(int sockfd, struct sockaddr *addr, socklen_t *addrlen);//服务器阻塞等待客户端连接
• addr:指向struct sockaddr *的指针,用于返回客户端的协议地址,
• addrlen:协议地址的长度。
如果accpet成功,那么其返回值是由内核自动生成的一个全新的描述字,代表与返回客户的TCP连接。

**

注意:

主机字节序:就是我们平常说的大端和小端模式:不同的CPU有不同的字节序类型,这些字节序是指整数在内存中保存的顺序,这个叫做主机序。引用标准的Big-Endian和Little-Endian的定义如下:
  a) Little-Endian就是低位字节排放在内存的低地址端,高位字节排放在内存的高地址端。
  b) Big-Endian就是高位字节排放在内存的低地址端,低位字节排放在内存的高地址端。
  
网络字节序:4个字节的32 bit值以下面的次序传输:首先是0~7bit,其次8~15bit,然后16~23bit,最后是24~31bit。这种传输次序称作大端字节序。由于TCP/IP首部中所有的二进制整数在网络中传输时都要求以这种次序,因此它又称作网络字节序。所以:在将一个地址绑定到socket的时候,请先将主机字节序转换成为网络字节序,
Socket 数据的粘包问题:客户端发送的多个数据包被当做一个数据包接收。也称数据的无边界性,read()/recv() 函数不知道数据包的开始或结束标志(实际上也没有任何开始或结束标志),只把它们当做连续的数据流来处理。

**

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值