基本函数接口

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. php在字符串中替换多个字符

    php替换多个字符串str_replace函数 echo str_replace(array("m","i"),array("n",&quo ...

  2. windows和ubuntu14.04双系统设置默认启动项

    首先开机或者重启,在启动项选择菜单处记住win7对应的序号,从上至下的序号从0开始计数,我的win7系统选项处于第5个,那么序号就应该是4,记住后,打开ubuntu系统. 2 按下Ctrl+alt+T ...

  3. Manthan, Codefest 17

    A. Tom Riddle's Diary time limit per test 2 seconds memory limit per test 256 megabytes input standa ...

  4. System.TypeInitializationException

    在连接数据库时,提示System.TypeInitializationException 数据库的连接字符串放在config文件中,而config中有两个文件,起初放在debug.comfig中,启动 ...

  5. 九度oj 题目1254:N皇后问题

    题目描述: N皇后问题,即在N*N的方格棋盘内放置了N个皇后,使得它们不相互攻击(即任意2个皇后不允许处在同一排,同一列,也不允许处在同一斜线上.因为皇后可以直走,横走和斜走如下图). 你的任务是,对 ...

  6. 封装自己DB

    DB.class.php <?php /** * Created by PhpStorm. * User: brady.wang * Date: 2017/11/10 * Time: 18:00 ...

  7. 【霍夫曼树】 poj 1521 Entropy

    poj.org/problem?id=1521 注意只有特殊情况:只有一种字母 #include<iostream> #include<cstdio> #include< ...

  8. Failed building wheel for Twisted

    在安装scrapy框架的过程中,pip install scrapy 出现报错信息: building 'twisted.test.raiser' extension error: Microsoft ...

  9. 【HDOJ5950】Recursive sequence(矩阵乘法,快速幂)

    题意:f[1]=a,f[2]=b,f[i]=2f[i-2]+f[i-1]+i^4(i>=3),多组询问求f[n]对2147493647取模 N,a,b < 2^31 思路:重点在于i^4的 ...

  10. 跳蚤 BZOJ 4310

    跳蚤 [问题描述] 很久很久以前,森林里住着一群跳蚤.一天,跳蚤国王得到了一个神秘的字符串,它想进行研究. 首先,他会把串分成不超过 k 个子串,然后对于每个子串 S,他会从S的所有子串中选择字典序最 ...