Java网络编程之IO模型阻塞与非阻塞简要分析

网友投稿 632 2022-12-08

java网络编程之IO模型阻塞与非阻塞简要分析

Java网络编程之IO模型阻塞与非阻塞简要分析

目录1.阻塞I/O模型2.非阻塞I/O模型

1.阻塞I/O模型

阻塞IO模型是常见的IO模型,在读写数据时客户端会发生阻塞。阻塞IO模型的工作流程为:

1.1在用户线程发出IO请求之后,内核会检查数据是否就绪,此时用户线程一直阻塞等待内存数据就绪;

1.2在内存数据就绪后,内核将数据复制到用户线程中,并返回I/O执行结果到用户线程,此时用户线程将解除阻塞状态并开始处理数据。

典型的阻塞I/O模型的例子为data= socket.read(),如果内核数据没有就绪, Socket线程就会一直阻塞在 reado中等待内核数据就绪。

2.非阻塞I/O模型

非阻塞I/O模型指用户线程在发起一个操作后,无须阻塞便可以马上得到内核返回的一个结果。如果内核返回的结果为fase,则表示内核数据还没准备好http://,需要稍后CXDzAaE再发起I/O操作。一旦内核中的数据准备好了,并且再次收到用户线程的请求,内核就会立刻将数据复制到用户线程中并将复制的结果通知用户线程。

在非阻塞IO模型中,用户线程需要不断询问内核http://数据是否就绪,在内存数据还未就绪时,用户线程可以处理其他任务,在内核数据就绪后可立即获取数据并执行相应的操作。典型的非阻塞IO模型一般如下:

import java.io.IOException;

import java.net.ServerSocket;

import java.net.Socket;

public class Test7 {

public static void main(String[] args) throws IOException {

ServerSocket socket=new ServerSocket();

while(true){

Socket data=socket.accept();

if (data!=null) {

//数据处理完毕

break;}

else {

//内核数据未处理完成,进行其他线程业务

}

}

}

}

以上就是Java网络编程之IO模型阻塞与非阻塞简要分析的详细内容,更多关于java模型IO阻塞与非阻塞的资料请关注我们其它相关文章!

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Java实现和电脑玩剪刀石头布游戏
下一篇:使用springBoot中的info等级通过druid打印sql
相关文章

 发表评论

暂时没有评论,来抢沙发吧~