聊聊IO流

聊聊IO流

1.什么是IO流?

计算机中的流就是连续的数据流,I/O流就是输入源和输出目标之间的数据流。

2.讲讲五种IO模型?

参考:IO模型

3.仔细讲讲IO多路复用模型, select, poll, epoll?

参考:select, poll, epoll详解

4.java中有哪些类型的流?

从两个角度来看: 从输入输出方面来讲: Java中有输入流和输出流 从流的编码方式上来讲:Java中有字节流和字符流。

输入/输出 字节流 字符流
输入流 InputStream Reader
输出流 OutputStream Writer
5.讲讲java中的io和nio, java中相关的类, 用了那种设计模式?

参考:IO和NIO的区别

NIO 有一个主要的类Selector,这个类似一个观察者,只要我们把需要探知的socketchannel告诉Selector,我们接着做别的事情,当有事件发生时,他会通知我们,传回一组SelectionKey,我们读取这些Key,就会获得我们刚刚注册过的socketchannel,然后,我们从这个Channel中读取数据,放心,包准能够读到,接着我们可以处理这些数据。

6.java读磁盘中某个文件的数据是怎样的流程?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
import java.io.BufferedReader;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStreamReader;

/**
* 使用文件流来读取固定磁盘文件
* add time 20170613
* @author wlshi
*
*/
public class Test{
public static void main(String[] args) throws IOException {
//文件所在路径
String filePath="C:\Users\admin\Desktop\1.txt";
//读取
FileInputStream fis = new FileInputStream(filePath);
// 字符流
InputStreamReader isr = new InputStreamReader(fis);
BufferedReader br = new BufferedReader(isr);
String line = null;
//对读取文件的内容进行处理,这里只进行输出
while ((line = br.readLine()) != null) {
// 一行一行地输出
System.out.println(line);
}
br.close();// 关闭文件
}
}
7.java从socket中读数据的流程是怎样的? 数据是怎么从网线传输到网卡再到java层处理的?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
server端:
package gxltest;

import java.io.IOException;
import java.io.InputStream;
import java.net.ServerSocket;
import java.net.Socket;
public class ServerDemo {
//UDP:发送端、接收端 (无连接)
//TCP:客户端、服务端 (要连接)先启动服务端,在启动客户端
/**
* @param args
* @throws IOException
*/
public static void main(String[] args) throws IOException {
//服务端接收客户端发送过来的数据,并打印在控制台上。
/*
* 建立tcp服务端的思路:
* 1,创建服务端socket服务。通过ServerSocket对象。
* 2,服务端必须对外提供一个端口,否则客户端无法连接。
* 3,获取连接过来的客户端对象。
* 4,通过客户端对象获取socket流读取客户端发来的数据
* 并打印在控制台上。
* 5,关闭资源。关客户端,关服务端。
*/
//1创建服务端对象。
ServerSocket ss = new ServerSocket(8088);
//监听应用所在服务器的10002端口,
//看有没有客户端连接过来,或者发送消息
//2,获取连接过来的客户端对象。
Socket s = ss.accept();//阻塞式.
String ip = s.getInetAddress().getHostAddress();
//获取连接过来客户端的IP地址
//3,通过socket对象获取输入流,要读取客户端发来的数据,
InputStream in = s.getInputStream();
byte[] buf = new byte[1024];
int len = in.read(buf);
String text = new String(buf,0,len);
System.out.println(ip+":"+text);
s.close();
ss.close();//关闭服务器,理论上是不用关的
}
}

client端:
package gxltest;

import java.io.IOException;
import java.io.OutputStream;
import java.net.Socket;
import java.net.UnknownHostException;
public class ClientDemo {
/**
* @param args
* @throws IOException
* @throws UnknownHostException
*/
public static void main(String[] args) throws UnknownHostException, IOException {
//客户端发数据到服务端
/*
* Tcp传输,客户端建立的过程。
* 1,创建tcp客户端socket服务。使用的是Socket对象。
* 建议该对象一创建就明确目的地。要连接的主机。
* 2,如果连接建立成功,说明数据传输通道已建立。
* 该通道就是socket流 ,是底层建立好的。 既然是流,说明这里既有输入,又有输出。
* 想要输入或者输出流对象,可以找Socket来获取。
* 可以通过getOutputStream(),和getInputStream()来获取两个字节流。
* 3,使用输出流,将数据写出。
* 4,关闭资源。
*/
//创建客户端socket服务。
//连接目标服务器的地址,192.168.1.100是目标服务器的地址,10002是目标服务器的端口
Socket socket = new Socket("192.168.1.100",8088);
//获取socket流中的输出流。 向服务器输出消息,即发消息到服务器
OutputStream out = socket.getOutputStream();
//使用输出流将指定的数据写出去。
out.write("tcp演示:哥们又来了!".getBytes());
//关闭资源。
socket.close();
}
}
8.什么是java序列化, 如何实现java序列化?

Java序列化:把Java对象转换为二进制的数据流流。 反序列化就是把字节序列恢复为Java对象的过程。

实现方式是实现java.io.Serializable接口.