Skip to content

Commit f63f5e9

Browse files
authored
Update Java NIO.md
1 parent dc5cd45 commit f63f5e9

File tree

1 file changed

+69
-4
lines changed

1 file changed

+69
-4
lines changed

Java/Java NIO.md

Lines changed: 69 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -1,8 +1,73 @@
1+
由于内容比较多,我下面放的是我更新在我的微信公众号上的链接,微信排版比较好看,更加利于阅读。每一篇文章下面我都把文章的主要内容给列出来了,便于大家学习与回顾。
12

2-
## 一些教程
3+
### [Java NIO 概览](https://mp.weixin.qq.com/s?__biz=MzU4NDQ4MzU5OA==&mid=2247483956&idx=1&sn=57692bc5b7c2c6dfb812489baadc29c9&chksm=fd985455caefdd4331d828d8e89b22f19b304aa87d6da73c5d8c66fcef16e4c0b448b1a6f791#rd)
34

4-
- ### 博客/文档
5+
### 主要内容:
6+
1. **NIO简介**:
57

6-
- ### 视频
8+
Java NIO 是 java 1.4, 之后新出的一套IO接口NIO中的N可以理解为Non-blocking,不单纯是New。
79

8-
- ### 书籍
10+
2. **NIO的特性/NIO与IO区别:**
11+
- 1)IO是面向流的,NIO是面向缓冲区的;
12+
- 2)IO流是阻塞的,NIO流是不阻塞的;
13+
- 3)NIO有选择器,而IO没有。
14+
3. **读数据和写数据方式:**
15+
- 从通道进行数据读取 :创建一个缓冲区,然后请求通道读取数据。
16+
17+
- 从通道进行数据写入 :创建一个缓冲区,填充数据,并要求通道写入数据。
18+
19+
4. **NIO核心组件简单介绍**
20+
- **Channels**
21+
- **Buffers**
22+
- **Selectors**
23+
24+
25+
### [Java NIO 之 Buffer(缓冲区)](https://mp.weixin.qq.com/s?__biz=MzU4NDQ4MzU5OA==&mid=2247483961&idx=1&sn=f67bef4c279e78043ff649b6b03fdcbc&chksm=fd985458caefdd4e3317ccbdb2d0a5a70a5024d3255eebf38183919ed9c25ade536017c0a6ba#rd)
26+
27+
### 主要内容:
28+
1. **Buffer(缓冲区)介绍:**
29+
- Java NIO Buffers用于和NIO Channel交互。 我们从Channel中读取数据到buffers里,从Buffer把数据写入到Channels;
30+
- Buffer本质上就是一块内存区;
31+
- 一个Buffer有三个属性是必须掌握的,分别是:capacity容量、position位置、limit限制。
32+
2. **Buffer的常见方法**
33+
- Buffer clear()
34+
- Buffer flip()
35+
- Buffer rewind()
36+
- Buffer position(int newPosition)
37+
3. **Buffer的使用方式/方法介绍:**
38+
- 分配缓冲区(Allocating a Buffer):
39+
```java
40+
ByteBuffer buf = ByteBuffer.allocate(28);//以ByteBuffer为例子
41+
```
42+
- 写入数据到缓冲区(Writing Data to a Buffer
43+
44+
**写数据到Buffer有两种方法:**
45+
46+
1.Channel中写数据到Buffer
47+
```java
48+
int bytesRead = inChannel.read(buf); //read into buffer.
49+
```
50+
2.通过put写数据:
51+
```java
52+
buf.put(127);
53+
```
54+
55+
4. **Buffer常用方法测试**
56+
57+
说实话,NIO编程真的难,通过后面这个测试例子,你可能才能勉强理解前面说的Buffer方法的作用。
58+
59+
60+
### [Java NIOChannel(通道)](https://mp.weixin.qq.com/s?__biz=MzU4NDQ4MzU5OA==&mid=2247483966&idx=1&sn=d5cf18c69f5f9ec2aff149270422731f&chksm=fd98545fcaefdd49296e2c78000ce5da277435b90ba3c03b92b7cf54c6ccc71d61d13efbce63#rd)
61+
1. **Channel(通道)介绍**
62+
- 通常来说NIO中的所有IO都是从 Channel(通道) 开始的。
63+
- NIO Channel通道和流的区别:
64+
2. **FileChannel的使用**
65+
3. **SocketChannelServerSocketChannel的使用**
66+
4. **DatagramChannel的使用**
67+
5. **Scatter / Gather**
68+
- Scatter: 从一个Channel读取的信息分散到N个缓冲区中(Buufer).
69+
- Gather:NBuffer里面内容按照顺序发送到一个Channel.
70+
6. **通道之间的数据传输**
71+
-Java NIO中如果一个channel是FileChannel类型的,那么他可以直接把数据传输到另一个channel。
72+
- transferFrom() :transferFrom方法把数据从通道源传输到FileChannel
73+
- transferTo() :transferTo方法把FileChannel数据传输到另一个channel

0 commit comments

Comments
 (0)