list.size()==0和list.isempty
时间: 2023-04-24 19:01:27 浏览: 68
list.size()==0和list.isEmpty()都表示列表为空。其中,list.size()==0是通过获取列表中元素的数量来判断列表是否为空,而list.isEmpty()是通过判断列表是否包含元素来判断列表是否为空。两者的结果是一样的,都表示列表中没有任何元素。
相关问题
mapper if标签中 list.size() 和list.size 的区别
在Mapper的`<if>`标签中,`list.size()` 和 `list.size` 在条件判断上有一些区别。
1. `<if test="list.size() > 0">...</if>`:这里的`list.size()` 是一个Ognl表达式,用于判断某个List类型的属性或参数的大小(元素个数)。如果List的大小大于0,则条件成立。
2. `<if test="list.size > 0">...</if>`:这里的`list.size` 是一个普通的属性或成员变量,用于判断一个整数类型的变量或参数是否大于0。但是在Mapper中,通常不会直接使用`list.size`,而是使用`list.isEmpty()`或者`list != null && list.size() > 0`来进行判断。
总结来说,`list.size()` 是一个Ognl表达式,用于判断List的大小是否大于0;而`list.size` 则是一个普通的整数类型属性,通常在Mapper中不直接使用。
优化以下java代码: LinkedList<SystemDynamics> getModelDataSysLog(){ //队列长度为0查询数据库 LocalDateTime now = LocalDateTime.now(); if(LogQueue.queue.size() == 0){ List<SystemDynamics> logs = service.getSysLog(null); for(SystemDynamics dynamics : logs){ dynamics.setLogTitle(dynamics.getOperatorName().substring(0,1)+"**"+dynamics.getLogTitle()); dynamics.setAfterTime(getTimeDifferent(now,dynamics.getOperatorTime())); } LogQueue.queue = new LinkedList<>(logs); if(logs.size()>0) LogQueue.dateTime = logs.get(0).getOperatorTime(); }else{ //队列长度不为0则从库里查数据添加到队列 List<SystemDynamics> logs = service.getSysLog(LogQueue.dateTime); for(SystemDynamics dynamics : logs){ dynamics.setLogTitle(dynamics.getOperatorName().substring(0,1)+"**"+dynamics.getLogTitle()); dynamics.setAfterTime(getTimeDifferent(now,dynamics.getOperatorTime())); } if(logs.size()>0){ if(logs.size() == LogQueue.queue.size()){ LogQueue.queue = new LinkedList<>(logs); }else{ logs.forEach(l->{ LogQueue.offer(l); }); } LogQueue.dateTime = LogQueue.queue.get(0).getOperatorTime(); } } return LogQueue.queue; }
可以考虑以下几个优化点:
1. 避免重复的代码:将for循环中的logs遍历和set操作提取出来,放到一个单独的方法中,避免重复的代码。
2. 使用局部变量:将重复使用的变量logs和now定义为局部变量,避免多次访问。
3. 代码简化:可以使用三目运算符对条件进行判断,避免过多的if-else语句,使代码更简洁。
优化后的代码如下所示:
```
LinkedList<SystemDynamics> getModelDataSysLog() {
LocalDateTime now = LocalDateTime.now();
if (LogQueue.queue.size() == 0) {
LogQueue.queue = new LinkedList<>(getLogs(null, now));
if (!LogQueue.queue.isEmpty()) {
LogQueue.dateTime = LogQueue.queue.get(0).getOperatorTime();
}
} else {
List<SystemDynamics> logs = getLogs(LogQueue.dateTime, now);
if (!logs.isEmpty()) {
LogQueue.queue.addAll(logs.size() == LogQueue.queue.size() ? new LinkedList<>(logs) : logs);
LogQueue.dateTime = LogQueue.queue.get(0).getOperatorTime();
}
}
return LogQueue.queue;
}
private List<SystemDynamics> getLogs(LocalDateTime dateTime, LocalDateTime now) {
List<SystemDynamics> logs = service.getSysLog(dateTime);
logs.forEach(l -> {
l.setLogTitle(l.getOperatorName().substring(0, 1) + "**" + l.getLogTitle());
l.setAfterTime(getTimeDifferent(now, l.getOperatorTime()));
});
return logs;
}
```