List<DriverTrack> driverTracks = driverService.selectDriverTrackByExample(example);
List<TrackVo> list = new ArrayList<TrackVo>();
TrackVo trackVo = new TrackVo();
if (driverTracks != null && driverTracks.size() > 0) {
for (DriverTrack driverTrack : driverTracks) {
trackVo.setLat(driverTrack.getLatitude());
trackVo.setLng(driverTrack.getLongitude());
list.add(trackVo);
}
}
上面的代码是我查询的司机轨迹在driverTracks中,然后我只想获取轨迹的经纬度放入到trackVo对象中,因为有多个经纬度,所以使用了List容器包含trackVo对象。
我当时想的时候把这个保存经纬度的对象在for循环外面创建,不放入到for里面。那么就不会消耗那么多的内存。如上,但是后面我发现我的list集合中的所有的经纬度都是同一个
而且是最后一个。一直不明白怎么回事?
原来是在for循环外面创建的对象是同一个对象,当我在for循环里面改了的这个对象值的时候,那些添加到list集合中的trackVo由于是同一个对象,所以那些加入到list中的对象的值也会随着改变,所以这中只能在for里面,每次创建一个对象。如下
List<DriverTrack> driverTracks = driverService.selectDriverTrackByExample(example);
List<TrackVo> list = new ArrayList<TrackVo>();
if (driverTracks != null && driverTracks.size() > 0) {
for (DriverTrack driverTrack : driverTracks) {
TrackVo trackVo = new TrackVo();
trackVo.setLat(driverTrack.getLatitude());
trackVo.setLng(driverTrack.getLongitude());
list.add(trackVo);
}
}
更好的写法是下面这个,性能会更好。
List<DriverTrack> driverTracks = driverService.selectDriverTrackByExample(example);
List<TrackVo> list = new ArrayList<TrackVo>();
if (driverTracks != null && driverTracks.size() > 0) {
TrackVo trackVo = null;
for (DriverTrack driverTrack : driverTracks) {
trackVo = new TrackVo();
trackVo.setLat(driverTrack.getLatitude());
trackVo.setLng(driverTrack.getLongitude());
list.add(trackVo);
}
}
因为这样写只创建了一个对象的引用,也就是在for循环里面去new对象的时候,都只是将这个引用指向不同的对象!