目前使用中包含以下几种
一、同步阻塞方式:客户端发送请求后,会一直等待服务器返回结果后才继续执行,常见的示例是传统的HTTP请求,基于java。
import java.io.IOException;
import java.io.InputStream;
import java.net.HttpURLConnection;
import java.net.URL;
public class SyncBlockingExample {
public static void main(String[] args) throws IOException {
URL url = new URL("http://example.com/api/users");
HttpURLConnection connection = (HttpURLConnection) url.openConnection();
connection.setRequestMethod("GET");
int responseCode = connection.getResponseCode();
if (responseCode == HttpURLConnection.HTTP_OK) {
InputStream inputStream = connection.getInputStream();
// 处理返回的数据流
}
connection.disconnect();
}
}
二、异步回调方式:客户端发送请求后,会立即返回,并注册一个回调函数,等待服务器处理完请求后调用回调函数通知客户端,常见的示例是Node.js的事件驱动编程模型,基于js。
const http = require('http');
http.get('http://example.com/api/users', (res) => {
let data = '';
res.on('data', (chunk) => {
data += chunk;
});
res.on('end', () => {
// 处理返回的数据
});
}).on('error', (err) => {
console.error(err);
});
三、异步非阻塞方式:客户端发送请求后,不会立即等待服务器返回结果,而是继续执行其他任务,通过轮询或者事件通知等方式获取结果,常见的示例是Java NIO中的异步非阻塞IO,基于java。
import java.io.IOException;
import java.io.InputStream;
import java.net.HttpURLConnection;
import java.net.URL;
public class SyncBlockingExample {
public static void main(String[] args) throws IOException {
URL url = new URL("http://example.com/api/users");
HttpURLConnection connection = (HttpURLConnection) url.openConnection();
connection.setRequestMethod("GET");
int responseCode = connection.getResponseCode();
if (responseCode == HttpURLConnection.HTTP_OK) {
InputStream inputStream = connection.getInputStream();
// 处理返回的数据流
}
connection.disconnect();
}
}
四、异步消息传递方式:客户端发送请求后,通过消息队列或者事件总线等方式将请求放入队列中,等待服务器处理,常见的示例是微服务架构中的消息中间件。
import org.springframework.amqp.rabbit.core.RabbitTemplate;
public class AsyncMessagingExample {
private RabbitTemplate rabbitTemplate;
public void sendMessage(String message) {
rabbitTemplate.convertAndSend("queueName", message);
// 发送消息到指定的队列
}
public void handleMessage(String message) {
// 处理接收到的消息
}
}