面试题合集
代码优化
- 如下给定一段代码可能导致性能问题,指出问题并给出优化代码
public List<User> getAllUsers() {
List<User> users = new ArrayList<>();
for (int i = 0; i < 1000; i++) {
users.add(new User(i,"User"+i));
}
return users;
}
这段代码的功能是创建一个包含1000个User对象的列表,虽然代码正确,但在性能方面存在潜在问题,特别是在大规模数据场景下。
问题分析:
- 1、频繁的对象创建:每次循环都会创建一个新的User对象,如果User对象的构造函数中有复杂的逻辑,可能会影响性能。
- 2、ArrayList的扩容:ArrayList默认初始容量为10,添加1000个元素时会触发多次扩容操作,扩容操作会创建新的数组并复制原有数据,带来额外的性能开销。
- 3、代码可读性:如果User对象的创建逻辑较为复杂,直接在循环中创建对象会降低代码的可读性和可维护性。
优化建议:
- 1、指定ArrayList的初始容量:通过指定初始容量为1000,避免扩容操作;
- 2、使用Stream简化代码:使用java 8 的Stream API可以简化代码,提高代码的可读性;
- 3、分离对象创建逻辑:如果User对象的创建逻辑较为复杂,可以将创建逻辑提取到一个单独的方法中,提高代码的可维护性。
优化后的代码:
public List<User> getAllUsers() {
List<User> users = new