基本函数接口

socket函数

#include <sys/socket.h>

int socket(int family, int type, int protocol);

成功时返回一个非负整数,与文件描述符类似,称为套接字描述符 sockfd。各参数的意义:

  1. family 指明协议族。取值为以下中的一个:

    • AF_INET --> ipv4协议
    • AF_INET6 --> ipv6协议
    • AF_LOCOL --> Unix域协议
    • AF_ROUTE --> 路由套接字
    • AF_KEY --> 密钥套接字
  2. type 指明套接字类型。取值为以下中的一个:

    • SOCK_STREAM --> 字节流套接字
    • SOCK_DGRAM --> 数据报套接字
    • SOCK_SEQPACKET --> 有序分组套接字
    • SOCK_RAW --> 原始套接字
  3. protocol 设为某个协议类型常值。设为0时,选择所给定family和type组合的系统默认值。

    • IPPROTO_TCP --> TCP传输协议
    • IPPROTO_UDP --> UDP传输协议
    • IPPTORO_SCTP --> SCTP传输协议

connect 函数

#include <sys/socket.h>
int connect(int sockfd, const struct sockaddr *servaddr, socklen_t addrlen);

connect由客户端程序调用,用来建立与TCP服务器的连接。成功返回0, 出错返回-1

  • sockfd 是socket()函数返回的套接字描述符
  • servaddr 指向套接字地址结构的指针
  • addrlen 套接字地址结构的大小

bind

#include <sys/socket.h>
int bind(int sockfd, const struct sockaddr *myaddr, socklen_t addrlen);

bind把一个本地协议地址赋予一个套接字。对于网际网协议,协议地址是IP+端口号的组合。

对于服务器上的某个服务,如果把特定的IP和端口绑定到这个服务进程的套接字上,则客户端发过来的连接信息中目的地址和目的端口必须为这里指定的IP和端口。

对于客户端,如果绑定IP和端口到套接字上,则该套接字上发送的IP数据报指派了源IP地址。而客户端通常不做这些绑定,当要连接服务器时,内核为套接字选择一个临时端口,并根据外出网络接口来选择源IP地址。

listen

#include <sys/socket.h>
int listen(int sockfd, int backlog);
  1. 当socket函数创建一个套接字时,它被假设为一个主动套接字,将要调用connect去发起连接。listen可以把它转换为被动套接字,指示内核应该接受指向该套接字的连接请求。
  2. backlog 规定内核为相应套按字排队的最大连接个数。

内核为一个给定的监听套接字维护两个队列:

  • 未完成连接队列
  • 已完成连接队列

accept

#include <sys/socket.h>
int accept(int sockfd, struct sockaddr *cliaddr, socklen_t *addrlen);

accept()函数由TCP服务器调用,用于从已完成连接队列头返回下一个已完成连接。 如果已完成队列为空,则进程进入休眠。

cliaddr 返回已连接的对端进程协议地址结构,addrlen是对端协议地址结构的长度。

accept()成功则返回值是一个全新的描述符,代表与所返回客户端的连接,称为已连接套接字。

close

关闭套接字,内核中该套接字描述符的引用计数会减1。


习题

  1. 头文件<netinet/in.h>中定义的INADDR_常值是主机字节序的。我们应该如何辨别?

  2. 把图1-5改为在connect成功返回后调用getsockname。使用sock_ntop显示赋予TCP套接字的本地IP地址和本地端口号。你的系统的临时端口在什么范围内?

  3. 在一个并发服务器中,假设fork调用返回后子进程先运行,而且子进程承受后在fork调用返回父进程之前就完成对客户端的服务。图4-13中的两个close调用将会发生什么?

  4. 在图4-11中,先把服务器的商品号从13改为9999,再删掉listen调用,将会发生什么?

  5. 继续上一题,删掉bind调用,但是保留listen调用, 又将发生什么?

4. 基本TCP套接字编程的更多相关文章

  1. 【UNIX网络编程(四)】TCP套接字编程具体分析

    引言: 套接字编程事实上跟进程间通信有一定的相似性,可能也正由于此.stevens这位大神才会将套接字编程与进程间的通信都归为"网络编程",并分别写成了两本书<UNP1> ...

  2. UNP学习笔记1——基本TCP套接字编程

    1 套接字地址结构 大多数套接字函数都需要一个指向套接字地址结构的指针作为参数.每个协议族都定义了自己的套接字结构.这些套接字的结构以sockaddr_开头,以每个协议族唯一的后缀名结尾. 1.1 I ...

  3. TCP套接字编程模型及实例

    摘要:     本文讲述了TCP套接字编程模块,包括服务器端的创建套接字.绑定.监听.接受.读/写.终止连接,客户端的创建套接字.连接.读/写.终止连接.先给出实例,进而结合代码分析. PS:本文权当 ...

  4. 初探网络编程--TCP套接字编程演示

    今天看了一下<计算机网络:自顶向下方法>,也就是计算机网络的教材的应用层一章,决定实现以下后面的Java C/S应用程序的例子,用来演示TCP和UDP套接字编程. 程序流程如下: 1.一台 ...

  5. 套接字编程相关函数(2:TCP套接字编程相关函数)

    本文摘录自<UNIX网络编程 卷1>. 基本套接字函数 socket函数 为了执行网络I/O,一个进程必须做的第一件事就是调用socket函数,指定期望的通信协议类型.其定义如下: #in ...

  6. TCP套接字编程

    一.套接字(socket)函数 图1给出了在一个TCP客户与服务器通信的流程.服务器首先启动,稍后某个客户启动,它试图连接到服务器.假设客户给服务器发送一个请求,服务器处理该请求,并且给客户发回一个相 ...

  7. 【UNIX网络编程(二)】基本TCP套接字编程函数

    基于TCP客户/server程序的套接字函数图例如以下: 运行网络I/O.一个进程必须做的第一件事就是调用socket函数.指定期望的通信协议类型. #include <sys/socket.h ...

  8. <网络编程>基本TCP套接字编程

    tcp提供了可靠传输,当tcp向另一端发送数据的时候,要求对端返回一个确认.如果没有接收到确认,tcp就重传数据并且等待更长时间,数次重传失败后,tcp才放弃. 建立一个tcp连接会发生如下事情: 服 ...

  9. unix网络编程——TCP套接字编程

    TCP客户端和服务端所需的基本套接字.服务器先启动,之后的某个时刻客户端启动并试图连接到服务器.之后客户端向服务器发送请求,服务器处理请求,并给客户端一个响应.该过程一直持续下去,直到客户端关闭,给服 ...

  10. unix网络编程第四章----基于TCP套接字编程

    为了执行网络I/O操作.进程必须做的第一件事情就是调用Socket函数.指定期待的通信协议 #include<sys/socket.h> int socket(int family,int ...

随机推荐

  1. iphone丢了以后发现关机了怎么办?

    有好几个办法都可以尝试一下: 1. "ICCID法",但目前这个办法只能寻找苹果iPhone手机,而对于安卓手机,则不能采取相同的方法进行寻找.之所以能采取该方法寻找苹果 iPho ...

  2. python3--__getattr__和__setattr__捕捉属性的一个引用

    __getattr__和__setattr__捕捉属性的一个引用 __getattr__方法是拦截属性点号运算.更确切地说,当通过对未定义(不存在)属性名称和实例进行点号运算时,就会用属性名称为字符串 ...

  3. 网页QQ唤起

    网页QQ唤起 <html> <head> <meta http-equiv="Content-Type" content="text/htm ...

  4. web文件上传大小限制

    最近在项目中遇到上传文件,对上传文件的大小需要进行限制,这里学习和整理了一下一些常规的文件大小限制的方法. 一般分为两种方式,一种是服务器端判断文件大小进行限制,这种方法的存在明显的缺陷,当用户过多后 ...

  5. 算法复习——单调队列(sliding windows,ssoi)

    题目: 题目描述 给你一个长度为 N 的数组,一个长为 K 的滑动的窗体从最左移至最右端,你只能见到窗口的 K 个整数,每次窗体向右移动一位,如下表:

  6. NIO Channel的学习笔记总结

    摘自:http://blog.csdn.net/tsyj810883979/article/details/6876603 1.1  非阻塞模式 Java  NIO非堵塞应用通常适用用在I/O读写等方 ...

  7. 洛谷P2676 超级书架

    题目描述 Farmer John最近为奶牛们的图书馆添置了一个巨大的书架,尽管它是如此的大,但它还是几乎瞬间就被各种各样的书塞满了.现在,只有书架的顶上还留有一点空间. 所有N(1 <= N & ...

  8. PHP验证码显示不出来

    PHP验证码显示不出来 验证码图片显示不出来,原因一般有三种(网上基本一致这几种原因): (1)php没有安装gd2模块,可以使用phpinfo()函数查看. (2)代码很可能是使用了像editpul ...

  9. HDU 1394 线段树求逆序对

    Minimum Inversion Number Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java ...

  10. LightOJ1234 Harmonic Number 调和级数求和

    [题目] [预备知识] ,其中r是欧拉常数,const double r= 0.57721566490153286060651209; 这个等式在n很大 的时候 比较精确. [解法]可以在 n较小的时 ...