Java网络编程学习A轮_05_Socket编程】的更多相关文章

示例代码: https://github.com/gordonklg/study,socket module A. Socket 编程简单例子 最简单的 Socket 编程是通过回车/换行符,整行读取字符串.网上代码随便抄抄便是. gordon.study.socket.basic.LineSeparateEchoServer.java 代码略 B. 简单的自定义协议 对于传输内容包含回车/换行符的通讯需求,可以使用自定义协议. 此处演示一个很简单的协议: 第一个字节代表类型,1表示为文本,0表…
A. A轮目标 复习网络编程基础知识,重点学习下TCP三次握手四次挥手,以及可能引发的异常情况. 回顾 Socket 编程,好多年没写(chao)过相关代码了. 重学 NIO,以前学的基本忘光了,毕竟从来没在项目中用过. 学习 Netty,了解基本用法,写一个简单项目练手. 扫读 Netty 核心源码,了解其线程模型,重点学习 Netty 如何使用 NIO. 搜罗面试题,查漏补缺. B. 基础知识 参考资料:<Java网络编程 第四版> 网际层(internet layer): 定义了数据位和…
参考资料: 老外写的教程,很适合入门:http://tutorials.jenkov.com/java-nio/index.html 上面教程的译文:http://ifeve.com/overview/ 示例代码: https://github.com/gordonklg/study,socket module A. 摘要 因为有现成的教程,本文只做摘要. NIO 有三宝,channel.buffer.selector Channel 与 Stream 很相似,除了: Channel 同时支持读…
参考资料: 了解 Java NIO 的 Reactor 模型,大神 Doug Lea 的 PPT Scalable IO in Java 必看:http://gee.cs.oswego.edu/dl/cpjslides/nio.pdf 示例代码: https://github.com/gordonklg/study,socket module A. 单线程版 Reactor 相当于一个中央事件收集分发器.一方面,Reactor 通过 Selector 可以收到已经准备完毕的事件通知,另一方面,R…
示例代码: https://github.com/gordonklg/study,socket module A. LineSeparate 基于 Buffer 实现逐行读取的 EchoServer 比传统 Socket 编程困难,相当于需要自己通过 Buffer 实现 BufferedReader 的 readLine 功能. 代码如下,假设单行不超过256字节,支持 Win 和 Linux(不支持单 \r 作为换行符)系统,空行忽略. 代码就不分析了,写了好久才跑对测试,分包粘包真是麻烦,要…
参考资料: http://www.jellythink.com/archives/705 示例代码: https://github.com/gordonklg/study,socket module A. TCP 四次挥手 下图描述了 TCP 整个生命周期从建立连接到断开连接的逻辑: 下面的测试代码完美模拟了上图 gordon.study.socket.basic.wireshark.TcpLifecycle.java public class TcpLifecycle { @SuppressW…
参考资料: https://huoding.com/2016/01/19/488 示例代码: https://github.com/gordonklg/study,socket module A. CLOSE_WAIT 有时会出现服务器响应极慢.假死的现象,查看 netstat 会发现服务器上存在大量未关闭的 CLOSE_WAIT 状态连接.我们分析下原因. 首先,CLOSE_WAIT 是被动关闭方才会出现的状态.我们模拟一个场景,客户端建立大量 Socket 连接,同时为每个 Socket 设…
参考资料: https://huoding.com/2013/11/21/299 https://hpbn.co/building-blocks-of-tcp/#three-way-handshake 示例代码: https://github.com/gordonklg/study,socket module A. Wireshark 免费抓包工具,谁用谁知道. 根据端口过滤 frame 的方法:tcp.port==8888 默认安装的 Winpcap 不能对 localhost 抓包,建议安装…
Java的并发编程是依赖虚拟机内存模型的三个特性实现的: (1).原子性(Atomicity): 原子性是指不可再分的最小操作指令,即单条机器指令,原子性操作任意时刻只能有一个线程,因此是线程安全的. Java内存模型中通过read.load.assign.use.store和write这6个操作保证变量的原子性操作. long和double这两个64位长度的数据类型java虚拟机并没有强制规定他们的read.load.store和write操作的原子性,即所谓的非原子性协定,但是目前的各种商业…
文的主要内容如下: 1.网络中进程之间如何通信? 2.Socket是什么? 3.socket的基本操作 3.1.socket()函数 3.2.bind()函数 3.3.listen().connect()函数 3.4.accept()函数 3.5.read().write()函数等 3.6.close()函数 4.socket中TCP的三次握手建立连接详解 5.socket中TCP的四次握手释放连接详解 6.一个例子(实践一下) 1.网络中进程之间如何通信? 本地的进程间通信(IPC)有很多种方…