第1章 概述 1
1.1 什么是网络 1
1.1.1 ISO/OSI参考模型 2
1.1.2 TCP/IP协议 3
1.2 什么是网络程序设计 5
1.2.1 网络程序的模式 6
1.2.2 为什么使用Java 6
第2章 Java的输入和输出 8
2.1 流 8
2.2 流的分类 9
2.3 流类概览 11
2.3.1 InputStream类分支 11
2.3.2 OutputStream类分支 12
2.3.3 Reader类分支 13
2.3.4 Writer类分支 14
2.3.5 IO异常 15
2.4 流类详解 15
2.4.1 InputStream类的常用方法 15
2.4.2 OutputStream类的常用方法 20
2.4.3 Reader类的常用方法 22
2.4.4 Writer类的常用方法 24
2.4.5 文件流 26
2.4.6 数组流 29
2.4.7 基本数据类型流 33
2.4.8 缓冲流 37
2.4.9 对象流 40
2.4.10 管道流 43
2.4.11 序列字节流 46
2.4.12 打印输出流 48
2.4.13 字节流与字符流之间的桥梁流 50
2.5 标准输入和输出 52
2.5.1 System类 52
2.5.2 Scanner类 54
2.6 压缩流类 55
2.6.1 GZIP压缩与解压缩 56
2.6.2 ZIP压缩与解压缩 58
2.7 如何选择流 61
第3章 IP地址和URL 62
3.1 IP地址和名字 62
3.1.1 主机和端口 62
3.1.2 IP地址 64
3.1.3 网络连通性 70
3.2 InetAddress类 72
3.2.1 创建InetAddress对象 72
3.2.2 InetAddress类的其他方法 77
3.3 SocketAddress类 78
3.4 URI类和URL类 79
3.4.1 URI类 80
3.4.2 URL类 85
3.4.3 URL的组成 86
3.4.4 从URL获得数据 87
3.4.5 URLConnection类 91
3.4.6 URLStreamHandler类 97
第4章 基于TCP的通信 100
4.1 Socket 101
4.2 Socket类 103
4.2.1 Socket类的构造方法 104
4.2.2 控制Socket连接 106
4.2.3 设置Socket的选项 114
4.3 ServerSocket类 122
4.3.1 构造ServerSocket 122
4.3.2 ServerSocket的常用方法 125
4.3.3 ServerSocket选项 129
4.4 多线程服务程序 131
第5章 基于UDP的通信 137
5.1 DatagramSocket类 138
5.1.1 构造DatagramSocket 139
5.1.2 DatagramSocket类的常用方法 141
5.1.3 设置DatagramSocket的选项 145
5.2 DatagramPacket类 149
5.2.1 DatagramPacket类的构造方法 149
5.2.2 DatagramPacket类的常用方法 150
5.2.3 程序实例 152
5.3 组播Socket 156
5.3.1 MulticastSocket类 156
5.3.2 构造MulticastSocket 156
5.3.3 MulticastSocket的常用方法 157
5.3.4 程序实例 157
第6章 NIO和NIO.2 160
6.1 NIO 160
6.2 缓冲区Buffer 161
6.2.1 Buffer类 161
6.2.2 Buffer类的使用方法 164
6.3 选择器Selector 171
6.3.1 Selector的作用 171
6.3.2 Selector和Channel 172
6.3.3 使用Selector 172
6.3.4 SelectionKey类 174
6.4 Channel接口 176
6.4.1 SocketChannel类 177
6.4.2 ServerSocketChannel类 180
6.4.3 DatagramChannel类 182
6.4.4 FileChannel类 184
6.5 示例程序 187
6.5.1 基于TCP的NIO通信示例 187
6.5.2 基于UDP的NIO通信示例 196
6.6 NIO.2 199
6.6.1 AsynchronousServerSocketChannel类 200
6.6.2 AsynchronousSocketChannel类 202
6.6.3 AsynchronousChannelGroup类 203
6.6.4 示例 204
6.7 选择IO还是NIO 208
第7章 多线程和并发 209
7.1 创建线程 209
7.1.1 创建线程的方法 210
7.1.2 线程的状态 213
7.2 线程类的方法 214
7.3 同步Synchronization 219
7.3.1 同步方法 220
7.3.2 同步代码块 221
7.4 线程间的协调 224
7.4.1 唤醒和等待 224
7.4.2 死锁 229
7.5 并发 231
7.5.1 Lock接口 231
7.5.2 Future接口和Callable接口 233
7.5.3 Executor接口和ExecutorService接口 235
7.5.4 Executors类 238
7.5.5 CountDownLatch类 241
7.5.6 程序示例 243
附录 TCP端口列表 250