4. 基本TCP套接字编程
基本函数接口
socket函数
#include <sys/socket.h>
int socket(int family, int type, int protocol);
成功时返回一个非负整数,与文件描述符类似,称为套接字描述符 sockfd。各参数的意义:
family 指明协议族。取值为以下中的一个:
- AF_INET --> ipv4协议
- AF_INET6 --> ipv6协议
- AF_LOCOL --> Unix域协议
- AF_ROUTE --> 路由套接字
- AF_KEY --> 密钥套接字
type 指明套接字类型。取值为以下中的一个:
- SOCK_STREAM --> 字节流套接字
- SOCK_DGRAM --> 数据报套接字
- SOCK_SEQPACKET --> 有序分组套接字
- SOCK_RAW --> 原始套接字
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);
- 当socket函数创建一个套接字时,它被假设为一个主动套接字,将要调用connect去发起连接。listen可以把它转换为被动套接字,指示内核应该接受指向该套接字的连接请求。
- backlog 规定内核为相应套按字排队的最大连接个数。
内核为一个给定的监听套接字维护两个队列:
- 未完成连接队列
- 已完成连接队列
accept
#include <sys/socket.h>
int accept(int sockfd, struct sockaddr *cliaddr, socklen_t *addrlen);
accept()函数由TCP服务器调用,用于从已完成连接队列头返回下一个已完成连接。 如果已完成队列为空,则进程进入休眠。
cliaddr 返回已连接的对端进程协议地址结构,addrlen是对端协议地址结构的长度。
accept()成功则返回值是一个全新的描述符,代表与所返回客户端的连接,称为已连接套接字。
close
关闭套接字,内核中该套接字描述符的引用计数会减1。
习题
头文件<netinet/in.h>中定义的INADDR_常值是主机字节序的。我们应该如何辨别?
把图1-5改为在connect成功返回后调用getsockname。使用sock_ntop显示赋予TCP套接字的本地IP地址和本地端口号。你的系统的临时端口在什么范围内?
在一个并发服务器中,假设fork调用返回后子进程先运行,而且子进程承受后在fork调用返回父进程之前就完成对客户端的服务。图4-13中的两个close调用将会发生什么?
在图4-11中,先把服务器的商品号从13改为9999,再删掉listen调用,将会发生什么?
继续上一题,删掉bind调用,但是保留listen调用, 又将发生什么?
4. 基本TCP套接字编程的更多相关文章
- 【UNIX网络编程(四)】TCP套接字编程具体分析
引言: 套接字编程事实上跟进程间通信有一定的相似性,可能也正由于此.stevens这位大神才会将套接字编程与进程间的通信都归为"网络编程",并分别写成了两本书<UNP1> ...
- UNP学习笔记1——基本TCP套接字编程
1 套接字地址结构 大多数套接字函数都需要一个指向套接字地址结构的指针作为参数.每个协议族都定义了自己的套接字结构.这些套接字的结构以sockaddr_开头,以每个协议族唯一的后缀名结尾. 1.1 I ...
- TCP套接字编程模型及实例
摘要: 本文讲述了TCP套接字编程模块,包括服务器端的创建套接字.绑定.监听.接受.读/写.终止连接,客户端的创建套接字.连接.读/写.终止连接.先给出实例,进而结合代码分析. PS:本文权当 ...
- 初探网络编程--TCP套接字编程演示
今天看了一下<计算机网络:自顶向下方法>,也就是计算机网络的教材的应用层一章,决定实现以下后面的Java C/S应用程序的例子,用来演示TCP和UDP套接字编程. 程序流程如下: 1.一台 ...
- 套接字编程相关函数(2:TCP套接字编程相关函数)
本文摘录自<UNIX网络编程 卷1>. 基本套接字函数 socket函数 为了执行网络I/O,一个进程必须做的第一件事就是调用socket函数,指定期望的通信协议类型.其定义如下: #in ...
- TCP套接字编程
一.套接字(socket)函数 图1给出了在一个TCP客户与服务器通信的流程.服务器首先启动,稍后某个客户启动,它试图连接到服务器.假设客户给服务器发送一个请求,服务器处理该请求,并且给客户发回一个相 ...
- 【UNIX网络编程(二)】基本TCP套接字编程函数
基于TCP客户/server程序的套接字函数图例如以下: 运行网络I/O.一个进程必须做的第一件事就是调用socket函数.指定期望的通信协议类型. #include <sys/socket.h ...
- <网络编程>基本TCP套接字编程
tcp提供了可靠传输,当tcp向另一端发送数据的时候,要求对端返回一个确认.如果没有接收到确认,tcp就重传数据并且等待更长时间,数次重传失败后,tcp才放弃. 建立一个tcp连接会发生如下事情: 服 ...
- unix网络编程——TCP套接字编程
TCP客户端和服务端所需的基本套接字.服务器先启动,之后的某个时刻客户端启动并试图连接到服务器.之后客户端向服务器发送请求,服务器处理请求,并给客户端一个响应.该过程一直持续下去,直到客户端关闭,给服 ...
- unix网络编程第四章----基于TCP套接字编程
为了执行网络I/O操作.进程必须做的第一件事情就是调用Socket函数.指定期待的通信协议 #include<sys/socket.h> int socket(int family,int ...
随机推荐
- BRVAH(让RecyclerView变得更高效) (2)
本文来自网易云社区 作者:吴思博 1.2 宫格和列表的混排样式 关于 Grid 和List 的混排样式,Grid 样式是一行有多个,而 List样式是一行只有一个. 我们可以把 List 样式看成是G ...
- 爬虫开发python工具包介绍 (4)
本文来自网易云社区 作者:王涛 此处我们给出几个常用的代码例子,包括get,post(json,表单),带证书访问:Get 请求 @gen.coroutine def fetch_url(): ...
- C/C++复杂类型声明
曾经碰到过让你迷惑不解.类似于int * (* (*fp1) (int) ) [10];这样的变量声明吗?本文将由易到难,一步一步教会你如何理解这种复杂的C/C++声明. 我们将从每天都能碰到的较 ...
- c++ string char* 获取输入值的区别
#include <iostream> #include <string> using namespace std; void reverseStr(string &s ...
- 【LeetCode】Maximum Subarray(最大子序和)
这道题是LeetCode里的第53道题. 题目描述: 给定一个整数数组 nums ,找到一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和. 示例: 输入: [-2,1,-3,4,-1 ...
- OpenJ_Bailian——4115鸣人和佐助(带状态的A*)
鸣人和佐助 Time Limit: 1000MS Memory Limit: 65536KB 64bit IO Format: %I64d & %I64u Submit Status Desc ...
- HDU 1565 方格取数(1) ——插头DP
[题目分析] 其实直接状压就可以了. 但是有点闲,又写了一个可读性极差,智商低下,很(gou)好(pi)的代码 [代码] #include <cstdio> #include <cs ...
- Codevs 2956 排队问题
2956 排队问题 时间限制: 1 s 空间限制: 32000 KB 题目等级 : 黄金 Gold 题目描述 Description 有N个学生去食堂,可教官规定:必须2人或3人组成一组,求有多少种不 ...
- MySQL导出数据库、数据库表结构、存储过程及函数【用】
一.导出数据库 我的mysql安装目录是D:\Program Files\MySQL\MySQL Server 5.5\bin\,导出文件预计放在D:\sql\ 在mysql的安装目录执行命令: my ...
- 最小费用最大流粗解 poj2516
最小费用最大流,一般解法如下: 在流量基础上,每条边还有权费用,即单位流量下的所需费用.在最大流量下,求最小费用.解法:在最大流算法基础上,每次按可行流增广改为每次用spfa按最小费用(用单位费用)增 ...