NIO 设计背后的基石:反应器模式,用于事件多路分离和分派的体系结构模式。
反应器(Reactor):用于事件多路分离和分派的体系结构模式
通常的,对一个文件描述符指定的文件或设备, 有两种工作方式: 阻塞 与非阻塞 。所谓阻塞方式的意思是指, 当试图对该文件描述符进行读写时, 如果当时没有东西可读,或者暂时不可写, 程序就进入等待 状态, 直到有东西可读或者可写为止。而对于非阻塞状态,
转载
2023-10-20 15:58:46
63阅读
阻塞socket和非阻塞socket读操作对于阻塞的socket,当socket的接收缓冲区中没有数据时,read调用会一直阻塞住,直到有数据到来才返回。当socket缓冲区中的数据量小于期望读取的数据量时,返回实际读取的字节数。当sockt的接收缓冲区中的数据大于期望读取的字节数时,读取期望读取的字节数,返回实际读取的长度。对于非阻塞socket而言,socket的接收缓冲区中有没
socket的阻塞与非阻塞同步:主动请求并等待IO操作完成的方式
异步:主动请求数据后,可以去处理其它任务,随后等待IO操作完毕的通知
阻塞:线程持续等待资源中数据准备完成,直到返回响应结果
非阻塞:线程直接返回结果,不会持续等待资源准备数据结束后才响应结果
socket()函数创建的socket默认是阻塞的
可以在创建socket时设置为非阻塞:(type参数中设置SOCK_NONBLOCK标志
转载
2023-05-29 13:12:25
420阅读
从socket中得到一个输入流InputStrean,然后从这个流中取数据,如果这个时候流里面的没有数据,可能是服务还没有发数据过来或发过来的数据也取完了,那么线程就会停在那里..直到服务器在发数据过来,从Socket的InputStream中取到了数据,这个线程才会向下走.所以当要和服务器交互通信的时候,就用一个while一真从Socket的流中数据取,流中
转载
2023-10-28 12:21:33
59阅读
Linux的网络编程有很多种写法,最简单的是阻塞式(Blocking)的网络程序,其次有非阻塞(Non-Blocking),多路复用(Multiplexing),异步(Asynchronous)模型等。阻塞模型:阻塞模型是最为简单的一种网络编程模型。顾名思义,该模型中,socket都工作在阻塞模式下,在调用相应的网络函数时,如accept, recv, send时,这些函数都会阻塞线程,直到soc
转载
2023-10-24 11:19:21
97阅读
## 实现Java阻塞Socket和非阻塞Socket
### 1. 流程图
```mermaid
flowchart TD
A(创建Socket) --> B(设置阻塞/非阻塞)
B --> C(连接服务器)
C --> D(读取/写入数据)
D --> E(关闭Socket)
```
### 2. 代码实现
#### 2.1 创建Socket
要创建一
1.线程阻塞主要有以下四方面原因:
a.线程执行了Thread.sleep(int n)方法,线程放弃CPU,睡眠n毫秒,然后恢复运行.
b.线程要执行一段同步代码,由于无法获得相关的同步锁,只好进入阻塞状态,等到获得了同步锁,才能恢复运行.
c.线程执行了一个对象的wait()方法,进入阻塞状态,只有等到其他线程执行了该对象的notify()
起先是在Socket编程时,服务端取得客户端发送的数据,但是在InputStream.read()的时候,一直停在那,然后取了解了read方法才知道阻塞问题代码示例://端口数据取得
byte[] b = new byte[1024];
in.read(b);//阻塞地方
String contents = new String(b).trim();//trim去除多余空格,否则,读进来的是byt
转载
2023-08-28 22:25:13
60阅读
一、项目背景 先说下我程序中Socket的用途吧,这样也好参照。我是想用手机的小程序跟阿里云服务器(Windows系统,非Linux系统)上的python程序进行通信,我的小程序会不定期拍摄照片上传到OSS云存储上,同时使用request(POST)的http请求将上传的图片的地址发送给阿里云上的python程序,然后python程序对地址的照
转载
2023-08-20 07:45:13
152阅读
一、并发并行并发:表示执行多个任务的能力并行:表示同一时刻执行多个任务二、模拟socket发送http请求三大步骤:创建连接 要发送的东西 然后数据回来接收 socket默认情况下阻塞 1 #!/usr/bin/env python
2 # -*- coding:utf-8 -*-
3
4 import socket
5
6 client = socket
转载
2023-08-08 09:47:04
116阅读
IO 多路复用是5种I/O模型中的一种。1、同步vs异步,阻塞vs非阻塞同步vs异步:同步:相互牵制,两者之间有一定的约束 异步:两者之间无关,互不牵制阻塞vs非阻塞阻塞:发出一个请求,如果条件不满足,会一直等待直到条件满足非阻塞:发出一个请求,如果条件不满足,则直接返回一个标志信息,而不会一直等待下去。并发vs并行并发数是指同时进行的任务数(如同时服务的 HTTP 请求)
1.TCP中的阻塞Socket和非阻塞Socket阻塞与非阻塞是对一个文件描述符指定的文件或设备的两种工作方式。 阻塞的意思是指,当试图对该文件描述符进行读写时,如果当时没有东西可读或者暂时不可写,程序就进入等待状态,直到有东西可读或者可写为止。 非阻塞的意思是,当没有东西可读或者不可写时,读写函数就马上返回,而不会等待。!!!阻塞模式在阻塞模式的套接字上,调用任何一个Wind
简单点说: 阻塞就是干不完不准回来, 非阻塞就是你先干,我先看看有其他事没有,完了告诉我一声。 我们拿最常用的send和recv两个函数来说吧。比如你调用send函数发送一定的Byte,在系统内部send做的工作其实只是把数据传输(Copy)到TCP/IP协议栈的输出缓冲区,它执行成功并不代表数据已经成功的发送出去了,如TCP/IP协议栈没有足够的可用缓冲区来保存你Copy过来的数据的话,这
转载
2023-08-03 15:11:35
126阅读
1.BIO/NIO/AIO介绍 BIO:阻塞到应用程序级别上IO的read或write方法上。 NIO:采用多路复用的方式select进行事件轮询的来进行实现同步非阻塞的方式。 AIO:异步非阻塞io。 java.nio包中的主要类 1.ServerSocketChanne类:Serve
用ServerSocket和Socket来编写服务器程序和客户程序,是Java网络编程的最基本的方式。这些服务器程序或客户程序在运行过程中常常会阻塞。例如当一个线程执行ServerSocket的accept()方法时,假如没有客户连接,该线程就会一直等到有了客户连接才从accept()方法返回。再例如当线程执行Socket的read()方法时,如果输入流中没有数据,该线程就会一直等到读入了足够的数
转载
2023-08-03 15:42:36
0阅读
Java网络编程之(三): TCP协议使用NIO实现非阻塞Soket通信前面介绍的网络通信程序是基于阻塞式API的————即当程序执行输入、输出操作后,在这些操作返回之前会一直阻塞该线程,所以服务器必须为每个客户端都提供一条独立线程进行处理,当服务器需要同时处理大量客户端时,这种做法会导致恨不能下降。使用NIO方式刚可以让服务器使用一个或几个有限几个线程来同时处理连接到服务器上的所有客
转载
2023-08-04 23:27:59
70阅读
传统的Socket是线程阻塞的,导致阻塞的原因有,sleep睡眠,wait等待,IO延迟等待、代码被同步等1.非阻塞 非阻塞指的是执行某些操作时,如果还没就绪,那么不会等待,立即返回,而等待事件的发生仍然是阻塞的 JDK中java.nio包提供了对非阻塞通信的支持,常
转载
2023-09-22 12:45:14
129阅读
非阻塞connect()和accept()一.select()函数 select()函数准备好读的条件: 1>.套接口有数据可读 2>.该连接的读这一半关闭(也就是接收了FIN的TCP连接)。对这样的套接口进行读操作将不阻塞并返回0(也就是返回EOF)。 3>.该套接口是一个侦听套接口且已完成的连接数不为0。 4>
linux 客户端 Socket 非阻塞connect编程(正文)/*开发过程与源码解析开发测试环境:虚拟机CentOS,windows网络调试助手 非阻塞模式有3种用途 1.三次握手同时做其他的处理。connect要花一个往返时间完成,从几毫秒的局域网到几百毫秒或几秒的广域网。这段时间可能有一些其他的处理要执行,比如数据准备,预处理等。 2.用这种技术建立多个连接。这在web浏览器中很普遍. 3
刚开始做项目时,要用到socket通信。那时为了弄清socket编程做了几个实验,主要是针对send和recv在几种特殊的情况下的返回值。1.阻塞socket:接收端和发送端正常频繁的接受和发送时,突然关闭接收端的socket(优雅的关闭,调用closesocket函数),此时的发送端的send函数返回-1,WSAGetLastError 的编码为10054.代表WSAECONNRE