网络编程之BIO
BIO是一种同步阻塞模式的网络处理方式,它的思想是一个线程处理一个连接,当连接没有事件方式的时候,线程会一直阻塞直到有相关事件发生然后进行处理,由于线程是需要消耗系统资源的,当连接数量多的情况下,调用了大量线程,就会导致系统无法提供资源建立线程进行处理,导致服务器无法接受网络请求,在高并发情况下不适合使用BIO模式,不过他的编程方式比较简单,在并发量较低的情况下可以使用该模式。
- BIO模式服务端代码
import java.io.IOException;
import java.net.InetSocketAddress;
import java.net.ServerSocket;
import java.net.Socket;
public class Server {
public static void main(String[] args) throws IOException {
//这里要注意在真正编程的时候不能直接将异常抛出,如果直接抛出程序将无法继续运行导致服务器无法提供服务
ServerSocket ss = new ServerSocket();
ss.bind(new InetSocketAddress("127.0.0.1", 8888));
while(true) {
Socket s = ss.accept(); //阻塞方法
new Thread(() -> {
handle(s);//调用线程处理连接
}).start();
}
}
static void handle(Socket s) {
try {
byte[] bytes = new byte[1024];
int len = s.getInputStream().read(bytes);
System.out.println(new String(bytes, 0, len));
s.getOutputStream().write(bytes, 0, len);
s.getOutputStream().flush();
} catch (IOException e) {
e.printStackTrace();
}
}
}
- BIO模式客户端代码
import java.io.IOException;
import java.io.OutputStream;
import java.net.Socket;
public class Client {
public static void main(String[] args) throws IOException {
Socket s = new Socket("127.0.0.1", 8888);
s.getOutputStream().write("HelloServer".getBytes());
s.getOutputStream().flush();
//s.getOutputStream().close();
System.out.println("write over, waiting for msg back...");
byte[] bytes = new byte[1024];
int len = s.getInputStream().read(bytes);
System.out.println(new String(bytes, 0, len));
s.close();
}
}
总结:
BIO模式编程比较简单,直接调用socketServer
绑定对应的端口和IP,然后死循环,等待连接请求调用accept
方法建立连接生产socket之后建立一个线程处理这个socket
就行了。