Netty和JDK源码来看Netty的NIO和JDK的NIO有什么不同
生活随笔
收集整理的這篇文章主要介紹了
Netty和JDK源码来看Netty的NIO和JDK的NIO有什么不同
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
JDK底層提供了NIO實現,在Linux環境會調用內核epoll。
但是Netty通過JNI的方式提供了Native Socket Transport,為什么Netty要自己搞一套NIO呢?
這篇文章帶你從jdk的源碼和Netty的源碼角度來分析為什么Netty要這么做。
JDK源碼:openjdk-8u40
Netty源碼:netty-4.1
1.先看JDK的NIO實現
Netty和JDK NIO都開始要調用內核的epoll,可以先看我之前寫的另一篇打個基礎:
從源碼和內核角度分析redis和nginx以及java NIO可以支持多大的并發
JDK 1.8 NIO Selector在linux平臺上的實現類是sun.nio.ch.EPollSelectorImpl,
這個類通過linux下的epoll系列系統調用實現NIO。
epoll主要包含3個系統調用:epollCreate,epollCtl,epollWait
這篇主要講epollCtl
epoll_ctl函數用于管理文件描述符的事件集,使用此函數可以注冊、修改、刪除一個或多個事件
EPollSelectorImpl.java構造函數初始化epoll
總結
以上是生活随笔為你收集整理的Netty和JDK源码来看Netty的NIO和JDK的NIO有什么不同的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 小说里好听的集团名字
- 下一篇: 狼王