UNIX 网络编程之道 卷2-进程间通信(第2版)+卷1套接字联网API(第3版)unix操作系统设

UNIX 网络编程之道 卷2-进程间通信(第2版)+卷1套接字联网API(第3版)unix操作系统设 pdf epub mobi txt 电子书 下载 2025

甘刚 编
图书标签:
  • UNIX网络编程
  • 进程间通信
  • 套接字编程
  • 网络API
  • 操作系统
  • Unix
  • 网络协议
  • 编程技术
  • 计算机科学
  • 技术图书
想要找书就要到 新城书站
立刻按 ctrl+D收藏本页
你会得到大惊喜!!
店铺: 中流砥柱图书专营店
出版社: 中国水利水电出版社
ISBN:9787508454672
商品编码:28819780607
丛书名: LINUXUNIX网络编程
开本:16
出版时间:2010-09-01

具体描述

套装参数

书    名:UNIX网络编程 卷2 进程间通信(第2版)+卷1 套接字联网API(第3版)【全2册】

作    者:[美]史蒂文斯 注意,匿名 译  [美]W. Richard Stevens Bill Fenner Andrew M. Rudoff 等著,匿名 译

I S B N :TZH11018 (987115367204 、9787115367198)

出 版 社:人民邮电出版社

出版时间:2015年8月第1版

印刷时间:2015年8月第1次印刷

字    数:全2册

页    数:全2册

开    本:16开

包    装:平装

原    价:218.00

编辑推荐

两卷本的《UNIX网络编程》是已故技术作家W. Richard Stevens的传世之作。卷2着重讨论如何让应用程序与在其他机器上的应用程序进行对话。

良好的进程间通信(IPC)机制是提高UNIX程序性能的关键。本书全面深入地讲解了各种进程间通信形式,包括消息传递、同步、共享内存及远程过程调用(RPC)。书中包含了大量经过优化的源代码,帮助读者加深理解。这些源代码可以从本书网站下载。

本书是网络研究和开发人员公认的参考书,无论网络编程的初学者还是网络专家都会大受裨益。

目录

部分 简介

第1章 简介

1.1 概述

1.2 进程、线程与信息共享

1.3 IPC对象的持续性

1.4 名字空间

1.5 fork、exec和exit对IPC对象的影响

1.6 出错处理:包裹函数

1.7 Unix标准

1.8 书中IPC例子索引表

1.9 小结

习题

第2章 Posix IPC

2.1 概述

2.2 IPC名字

2.3 创建与打开IPC通道

2.4 IPC权限

2.5 小结

习题

第3章 System V IPC

3.1 概述

3.2 key_t键和ftok函数

3.3 ipc_perm结构

3.4 创建与打开IPC通道

3.5 IPC权限

3.6 标识符重用

3.7 ipcs和ipcrm程序

3.8 内核限制

3.9 小结

习题

第二部分 消息传递

第4章 管道和FIFO

4.1 概述

4.2 一个简单的客户—服务器例子

4.3 管道

4.4 全双工管道

4.5 popen和pclose函数

4.6 FIFO

4.7 管道和FIFO的额外属性

4.8 单个服务器,多个客户

4.9 对比迭代服务器与并发服务器

4.10 字节流与消息

4.11 管道和FIFO限制

4.12 小结

习题

第5章 Posix消息队列

5.1 概述

5.2 mq_open、mq_close和mq_unlink函数

5.3 mq_getattr和mq_setattr函数

5.4 mq_send和mq_receive函数

5.5 消息队列限制

5.6 mq_notify函数

5.7 Posix实时信号

5.8 使用内存映射I/O实现Posix消息队列

5.9 小结

习题

第6章 System V消息队列

6.1 概述

6.2 msgget函数

6.3 msgsnd函数

6.4 msgrcv函数

6.5 msgctl函数

6.6 简单的程序

6.7 客户—服务器例子

6.8 复用消息

6.9 消息队列上使用select和poll

6.10 消息队列限制

6.11 小结

习题

第三部分 同步

第7章 互斥锁和条件变量

7.1 概述

7.2 互斥锁:上锁与解锁

7.3 生产者—消费者问题

7.4 对比上锁与等待

7.5 条件变量:等待与信号发送

7.6 条件变量:定时等待和广播

7.7 互斥锁和条件变量的属性

7.8 小结

习题

第8章 读写锁

8.1 概述

8.2 获取与释放读写锁

8.3 读写锁属性

8.4 使用互斥锁和条件变量实现读写锁

8.5 线程取消

8.6 小结

习题

第9章 记录上锁

9.1 概述

9.2 对比记录上锁与文件上锁

9.3 Posix fcntl记录上锁

9.4 劝告性上锁

9.5 强制性上锁

9.6 读出者和写入者的优先级

9.7 启动一个守护进程的副本

9.8 文件作锁用

9.9 NFS上锁

9.10 小结

习题

第10章 Posix信号量

10.1 概述

10.2 sem_open、sem_close和sem_unlink函数

10.3 sem_wait和sem_trywait函数

10.4 sem_post和sem_getvalue函数

10.5 简单的程序

10.6 生产者—消费者问题

10.7 文件上锁

10.8 sem_init和sem_destroy函数

10.9 多个生产者,单个消费者

10.10 多个生产者,多个消费者

10.11 多个缓冲区

10.12 进程间共享信号量

10.13 信号量限制

10.14 使用FIFO实现信号量

10.15 使用内存映射I/O实现信号量

10.16 使用System V信号量实现Posix信号量

10.17 小结

习题

第11章 System V 信号量

11.1 概述

11.2 semget函数

11.3 semop函数

11.4 semctl函数

11.5 简单的程序

11.6 文件上锁

11.7 信号量限制

11.8 小结

习题

第四部分 共享内存区

第12章 共享内存区介绍

12.1 概述

12.2 mmap、munmap和msync函数

12.3 在内存映射文件中给计数器持续加

12.4 4.4BSD匿名内存映射

12.5 SVR4/dev/zero内存映射

12.6 访问内存映射的对象

12.7 小结

习题

第13章 Posix共享内存区

13.1 概述

13.2 shm_open和shm_unlink函数

13.3 ftruncate和fstat函数

13.4 简单的程序

13.5 给一个共享的计数器持续加1

13.6 向一个服务器发送消息

13.7 小结

习题

第14章 System V共享内存区

14.1 概述

14.2 shmget函数

14.3 shmat函数

14.4 shmdt函数

14.5 shmctl函数

14.6 简单的程序

14.7 共享内存区限制

14.8 小结

习题

第五部分 远程过程调用

第15章 门

15.1 概述

15.2 door_call函数

15.3 door_create函数

15.4 door_return函数

15.5 door_cred函数

15.6 door_info函数

15.7 例子

15.8 描述符传递

15.9 door_sever_create函数

15.10 door_bind、door_unbind和door_revoke函数

15.11 客户或服务器的过早终止

15.12 小结

习题

第16章 Sun RPC

16.1 概述

16.2 多线程化

16.3 服务器捆绑

16.4 认证

16.5 超时和重传

16.6 调用语义

16.7 客户或服务器的过早终止

16.8 XDR:外部数据表示

16.9 RPC分组格式

16.10 小结

习题

后记

附录A 性能测量

附录B 线程入门

附录C 杂凑的源代码

附录D 精选习题解答

参考文献

索引

商品参数

书    名:UNIX网络编程 卷1 套接字联网API(第3版)

作    者:[美]W. Richard Stevens Bill Fenner Andrew M. Rudoff 等著,匿名 译

I S B N :9787115367198

出 版 社:人民邮电出版社

出版时间:2015年8月第1版

印刷时间:2015年8月第1次印刷

字    数:1363000

页    数:804

开    本:16开

包    装:平装

重    量:1475克

原    价:129.00元

 

 

目录

部分 简介和TCP/IP

第1章 简介 

1.1 概述 

1.2 一个简单的时间获取客户程序 

1.3 协议无关性 

1.4 错误处理:包裹函数 

1.5 一个简单的时间获取服务器程序 

1.6 本书中客户/服务器程序示例索引表 

1.7 OSI模型 

1.8 BSD网络支持历史 

1.9 测试用网络及主机 

1.10 Unix标准 

1.11 64位体系结构 

1.12 小结 

习题 

第2章 传输层:TCP、UDP和SCTP 

2.1 概述 

2.2 总图 

2.3 用户数据报协议(UDP) 

2.4 传输控制协议(TCP) 

2.5 流控制传输协议(SCTP) 

2.6 TCP连接的建立和终止 

2.7 TIME_WAIT状态 

2.8 SCTP关联的建立和终止 

2.9 端口号 

2.10 TCP端口号与并发服务器 

2.11 缓冲区大小及限制 

2.12 标准因特网服务 

2.13 常见因特网应用的协议使用 

2.14 小结 

习题 

第二部分 基本套接字编程

第3章 套接字编程简介 

3.1 概述 

3.2 套接字地址结构 

3.3 值—结果参数 

3.4 字节排序函数 

3.5 字节操纵函数 

3.6 inet_aton、inet_addr和inet_ntoa函数 

3.7 inet_pton和inet_ntop函数 

3.8 sock_ntop和相关函数 

3.9 readn、writen和readline函数 

3.10 小结 

习题 

第4章 基本TCP套接字编程 

4.1 概述 

4.2 socket函数 

4.3 connect函数 

4.4 bind函数 

4.5 listen函数 

4.6 accept函数 

4.7 fork和exec函数 

4.8 并发服务器 

4.9 close函数 

4.10 getsockname和getpeername函数 

4.11 小结 

习题 

第5章 TCP客户/服务器程序示例 

5.1 概述 

5.2 TCP回射服务器程序:main函数 

5.3 TCP回射服务器程序:str_echo函数 

5.4 TCP回射客户程序:main函数 

5.5 TCP回射客户程序:str_cli函数 

5.6 正常启动 

5.7 正常终止 

5.8 POSIX信号处理 

5.9 处理SIGCHLD信号 

5.10 wait和waitpid函数 

5.11 accept返回前连接中止 

5.12 服务器进程终止 

5.13 SIGPIPE信号 

5.14 服务器主机崩溃 

5.15 服务器主机崩溃后重启 

5.16 服务器主机关机 

5.17 TCP程序例子小结 

5.18 数据格式 

5.19 小结 

习题 

第6章 I/O复用:select和poll函数 

6.1 概述 

6.2 I/O模型 

6.3 select函数 

6.4 str_cli函数(修订版) 

6.5 批量输入 

6.6 shutdown函数 

6.7 str_cli函数(再修订版) 

6.8 TCP回射服务器程序(修订版) 

6.9 pselect函数 

6.10 poll函数 

6.11 TCP回射服务器程序(再修订版) 

6.12 小结 

习题 

第7章 套接字选项 

7.1 概述 

7.2 getsockopt和setsockopt函数 

7.3 检查选项是否受支持并获取默认值 

7.4 套接字状态 

7.5 通用套接字选项 

7.6 IPv4套接字选项 

7.7 ICMPv6套接字选项 

7.8 IPv6套接字选项 

7.9 TCP套接字选项 

7.10 SCTP套接字选项 

7.11 fcntl函数 

7.12 小结 

习题 

第8章 基本UDP套接字编程 

8.1 概述 

8.2 recvfrom和sendto函数 

8.3 UDP回射服务器程序:main函数 

8.4 UDP回射服务器程序:dg_echo函数 

8.5 UDP回射客户程序:main函数 

8.6 UDP回射客户程序:dg_cli函数 

8.7 数据报的丢失 

8.8 验证接收到的响应 

8.9 服务器进程未运行 

8.10 UDP程序例子小结 

8.11 UDP的connect函数 

8.12 dg_cli函数(修订版) 

8.13 UDP缺乏流量控制 

8.14 UDP中的外出接口的确定 

8.15 使用select函数的TCP和UDP回射服务器程序 

8.16 小结 

习题 

第9章 基本SCTP套接字编程 

9.1 概述 

9.2 接口模型 

9.3 sctp_bindx函数 

9.4 sctp_connectx函数 

9.5 sctp_getpaddrs函数 

9.6 sctp_freepaddrs函数 

9.7 sctp_getladdrs函数 

9.8 sctp_freeladdrs函数 

9.9 sctp_sendmsg函数 

9.10 sctp_recvmsg函数 

9.11 sctp_opt_info函数 

9.12 sctp_peeloff函数 

9.13 shutdown函数 

9.14 通知 

9.15 小结 

习题 

第10章 SCTP客户/服务器程序例子 

10.1 概述 

10.2 SCTP一到多式流分回射服务器程序:main函数 

10.3 SCTP一到多式流分回射客户程序:main函数 

10.4 SCTP流分回射客户程序:sctpstr_cli函数 

10.5 探究头端阻塞 

10.6 控制流的数目 

10.7 控制终结 

10.8 小结 

习题 

第11章 名字与地址转换 

11.1 概述 

11.2 域名系统 

11.3 gethostbyname函数 

11.4 gethostbyaddr函数 

11.5 getservbyname和getservbyport函数 

11.6 getaddrinfo函数 

11.7 gai_strerror函数 

11.8 freeaddrinfo函数 

11.9 getaddrinfo函数:IPv6 

11.10 getaddrinfo函数:例子 

11.11 host_serv函数 

11.12 tcp_connect函数 

11.13 tcp_listen函数 

11.14 udp_client函数 

11.15 udp_connect函数 

11.16 udp_server函数 

11.17 getnameinfo函数 

11.18 可重入函数 

11.19 gethostbyname_r和gethostbyaddr_r函数 

11.20 作废的IPv6地址解析函数 

11.21 其他网络相关信息 

11.22 小结 

习题 

第三部分 高级套接字编程

第12章 IPv4与IPv6的互操作性 

12.1 概述 

12.2 IPv4客户与IPv6服务器 

12.3 IPv6客户与IPv4服务器 

12.4 IPv6地址测试宏 

12.5 源代码可移植性 

12.6 小结 

习题 

第13章 守护进程和inetd服务器 

13.1 概述 

13.2 syslogd守护进程 

13.3 syslog函数 

13.4 daemon_init函数 

13.5 inetd守护进程 

13.6 daemon_inetd函数 

13.7 小结 

习题 

第14章 高级I/O函数 

14.1 概述 

14.2 套接字超时 

14.3 recv和send函数 

14.4 readv和writev函数 

14.5 recvmsg和sendmsg函数 

14.6 辅助数据 

14.7 排队的数据量 

14.8 套接字和标准I/O 

14.9 高级轮询技术 

14.10 T/TCP:事务目的TCP 

14.11 小结 

习题 

第15章 Unix域协议 

15.1 概述 

15.2 Unix域套接字地址结构 

15.3 socketpair函数 

15.4 套接字函数 

15.5 Unix域字节流客户/服务器程序 

15.6 Unix域数据报客户/服务器程序 

15.7 描述符传递 

15.8 接收发送者的凭证 

15.9 小结 

习题 

第16章 非阻塞式I/O 

16.1 概述 

16.2 非阻塞读和写:str_cli函数(修订版) 

16.3 非阻塞connect 

16.4 非阻塞connect:时间获取客户程序 

16.5 非阻塞connect:Web客户程序 

16.6 非阻塞accept 

16.7 小结 

习题 

第17章 ioctl操作 

17.1 概述 

17.2 ioctl函数 

17.3 套接字操作 

17.4 文件操作 

17.5 接口配置 

17.6 get_ifi_info函数 

17.7 接口操作 

17.8 ARP高速缓存操作 

17.9 路由表操作 

17.10 小结 

习题 

第18章 路由套接字 

18.1 概述 

18.2 数据链路套接字地址结构 

18.3 读和写 

18.4 sysctl操作 

18.5 get_ifi_info函数 

18.6 接口名字和索引函数 

18.7 小结 

习题 

第19章 密钥管理套接字 

19.1 概述 

19.2 读和写 

19.3 倾泻安全关联数据库 

19.4 创建静态安全关联 

19.5 动态维护安全关联 

19.6 小结 

习题 

第20章 广播 

20.1 概述 

20.2 广播地址 

20.3 单播和广播的比较 

20.4 使用广播的dg_cli函数 

20.5 竞争状态 

20.6 小结 

习题 

第21章 多播 

21.1 概述 

21.2 多播地址 

21.3 局域网上多播和广播的比较 

21.4 广域网上的多播 

21.5 源特定多播 

21.6 多播套接字选项 

21.7 mcast_join和相关函数 

21.8 使用多播的dg_cli函数 

21.9 接收IP多播基础设施会话声明 

21.10 发送和接收 

21.11 SNTP:简单网络时间协议 

21.12 小结 

习题 

第22章 高级UDP套接字编程 

22.1 概述 

22.2 接收标志、目的IP地址和接口索引 

22.3 数据报截断 

22.4 何时用UDP代替TCP 

22.5 给UDP应用增加可靠性 

22.6 捆绑接口地址 

22.7 并发UDP服务器 

22.8 IPv6分组信息 

22.9 IPv6路径MTU控制 

22.10 小结 

习题 

第23章 高级SCTP套接字编程 

23.1 概述 

23.2 自动关闭的一到多式服务器程序 

……

第31章 流

附录

参考文献

索引

内容推荐

本书是一部UNIX 网络编程的经典之作!进程间通信(IPC)几乎是所有Unix 程序性能的关键,理解IPC 也是理解如何开发不同主机间网络应用程序的必要条件。本书从对Posix IPC 和System V IPC 的内部结构开始讨论,全面深入地介绍了4 种IPC 形式:消息传递(管道、FIFO、消息队列)、同步(互斥锁、条件变量、读写锁、文件与记录锁、信号量)、共享内存(匿名共享内存、具名共享内存)及远程 过程调用(Solaris门、Sun RPC)。附录中给出了测量各种IPC 形式性能的方法。

本书内容详尽且具性,几乎每章都提供精选的习题,并提供了部分习题的答案,是网络研究和开发人员理想的参考书。

........

 

........

用户评价

评分

评分

评分

评分

评分

评分

评分

评分

评分

相关图书

本站所有内容均为互联网搜索引擎提供的公开搜索信息,本站不存储任何数据与内容,任何内容与数据均与本站无关,如有需要请联系相关搜索引擎包括但不限于百度google,bing,sogou

© 2025 book.cndgn.com All Rights Reserved. 新城书站 版权所有