接口开发完后,个人对于接下来接口优化的一些思考

优化点

入参的合法性和长度范围,必填项的检查验证

因为没有入参,所以不需要考虑。

批量思想解决N+1问题
java 复制代码
// 假设要查询100个订单及其对应的用户信息
List<Order> orders = orderMapper.selectList(new QueryWrapper<>().last("limit 100"));

// N+1问题: 循环查询每个订单的用户信息
for (Order order : orders) {
    // 每个订单都要单独发起一次SQL查询用户信息
    User user = userMapper.selectById(order.getUserId());
    order.setUserName(user.getName());
}
  • 1次查询订单列表
  • N次查询用户信息(N=订单数量)
    总计: N+1次查询
java 复制代码
-- 第1次查询
SELECT * FROM orders LIMIT 100;

-- 然后是N次单独的用户查询
SELECT * FROM users WHERE id = 1;
SELECT * FROM users WHERE id = 2;
SELECT * FROM users WHERE id = 3;
...
java 复制代码
// 1. 先查询订单列表
List<Order> orders = orderMapper.selectList(new QueryWrapper<>().last("limit 100"));

// 2. 收集所有用户ID
List<Long> userIds = orders.stream()
    .map(Order::getUserId)
    .collect(Collectors.toList());

// 3. 一次性批量查询所有用户信息
List<User> users = userMapper.selectBatchIds(userIds);

// 4. 构建用户ID到用户信息的映射
Map<Long, User> userMap = users.stream()
    .collect(Collectors.toMap(User::getId, u -> u));

// 5. 填充订单的用户信息
for (Order order : orders) {
    User user = userMap.get(order.getUserId());
    order.setUserName(user.getName());
}
java 复制代码
-- 第1次查询
SELECT * FROM orders LIMIT 100;

-- 第2次批量查询
SELECT * FROM users WHERE id IN (1,2,3,...);

批量查询只产生2条SQL,不限于读取(批量读取),写入(批量写入)也是一样的。

异步思想:解决长耗时问题

因为没有入参,所以不需要考虑

并行思想:把大任务拆分多个子任务,让多个子任务同时执行(人多力量大)
空间换时间思想:使用**++缓存++**降低耗时

使用缓存虽然可以提升用户体验,但是也会带来其他问题,如数据一致性问题。还有缓存穿透、缓存击穿、缓存雪崩、缓存淘汰等问题。

复用思想:线程连接池、数据库连接池

连接池的原理是通过预先创建一定数量的连接对象,并将其保存在池中。当需要使用连接时,从池中获取一个可用的连接对象,使用完毕后归还给池,而不是每次都创建和销毁连接对象。这样可以避免频繁地创建和销毁连接对象,提高系统性能和资源利用率。

数据量大的时候,使用压缩算法减少传输数据的时间

Content-Encoding 是 HTTP 协议中的一个头部字段,用于指示服务器对响应内容进行了何种类型的编码压缩。它的作用是告知客户端如何解码和还原服务器返回的压缩内容。

解耦思想:使用消息队列解除强耦合性
相关推荐
桦说编程4 小时前
Java 中如何创建不可变类型
java·后端·函数式编程
lifallen4 小时前
Java Stream sort算子实现:SortedOps
java·开发语言
IT毕设实战小研4 小时前
基于Spring Boot 4s店车辆管理系统 租车管理系统 停车位管理系统 智慧车辆管理系统
java·开发语言·spring boot·后端·spring·毕业设计·课程设计
没有bug.的程序员5 小时前
JVM 总览与运行原理:深入Java虚拟机的核心引擎
java·jvm·python·虚拟机
甄超锋5 小时前
Java ArrayList的介绍及用法
java·windows·spring boot·python·spring·spring cloud·tomcat
阿华的代码王国5 小时前
【Android】RecyclerView复用CheckBox的异常状态
android·xml·java·前端·后端
Zyy~5 小时前
《设计模式》装饰模式
java·设计模式
A尘埃5 小时前
企业级Java项目和大模型结合场景(智能客服系统:电商、金融、政务、企业)
java·金融·政务·智能客服系统
青云交6 小时前
Java 大视界 -- 基于 Java 的大数据可视化在城市交通拥堵治理与出行效率提升中的应用(398)
java·大数据·flink·大数据可视化·拥堵预测·城市交通治理·实时热力图
CHEN5_026 小时前
【Java基础面试题】Java基础概念
java·开发语言