问:初步理解网络IO
public class ServerDemo {
public static void main(String[] args) {
try {
ServerSocket serverSocket = new ServerSocket(8080);
Socket socket = serverSocket.accept();
InputStream inputStream = socket.getInputStream();
BufferedInputStream bufferedInputStream = new BufferedInputStream(inputStream);
int length = 0;
byte[] bytes = new byte[1024];
while ((length = bufferedInputStream.read(bytes)) != -1) {
System.out.println(new String(bytes,0,length,"UTF-8"));
}
} catch (IOException e) {
e.printStackTrace();
}
}
}
public class ClientDemo0 {
public static void main(String[] args) {
try {
Socket socket = new Socket("localhost", 8080);
OutputStream outputStream = socket.getOutputStream();
BufferedOutputStream outputStream1 = new BufferedOutputStream(outputStream);
outputStream1.write("你好".getBytes());
outputStream1.flush();
socket.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
问:Socket和ServerSocket
public class ServerSocketDemo {
public static void main(String[] args) {
ServerSocket serverSocket = null;
try {
serverSocket = new ServerSocket(8080);
Socket socket = serverSocket.accept();
System.out.println("客户端发起了一个链接操作" + socket.getPort());
// 字节转成字符 FileStreamReader
// 字符的缓存流读取 BufferedReader
BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(socket.getInputStream()));
// 只读取一行
String str = bufferedReader.readLine();
System.out.println("收到客户端消息:" + str);
BufferedWriter bufferedWriter = new BufferedWriter(new OutputStreamWriter(socket.getOutputStream()));
bufferedWriter.write("我以收到\n");
bufferedWriter.flush();
} catch (IOException e) {
e.printStackTrace();
}
}
}
public class ClientDemo {
public static void main(String[] args) {
try {
String host = "localhost";
int port = 8080;
Socket socket = new Socket(host, port);
OutputStream outputStream = socket.getOutputStream();
BufferedWriter bufferedWriter = new BufferedWriter(new OutputStreamWriter(outputStream));
bufferedWriter.write("发起消息 \n");
bufferedWriter.flush();
InputStream inputStream = socket.getInputStream();
BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(inputStream));
System.out.println(bufferedReader.readLine());
} catch (Exception e) {
}
}
}
图1-1:
问:网络通信协议分析
网络分层模型
图:请求发送模型
请求接受模型
问:网络通信底层原理
图1-1:
阻塞过程
阻塞的优化
问:基于Socket手写实现RPC框架
什么是rpc协议