public List> getTripListData() {
Map<String, Object> map = new HashMap<String, Object>();
map.put("img", R.drawable.moto);
map.put("name", "摩托罗拉(motorola)XT711 3G手机");
map.put("money", "2699元");
map.put("zhe", "9折");
list.add(map);
map = new HashMap<String, Object>();
map.put("img", R.drawable.iphone);
map.put("name", "iPhone4 16G版");
map.put("money", "5880元");
map.put("zhe", "8.5折");
list.add(map);
map = new HashMap<String, Object>();
map.put("img", R.drawable.samsung);
map.put("name", "三星(SAMSUNG)i9003 3G手机");
map.put("money", "3099元");
map.put("zhe", "9折");
list.add(map);
return list;
}
为什么以上三个map
不用map1 map2 map3 加以区分 ???
因为map在使用之前都重新声明了,就是重新new了,只占用内存一个,若用map1 map2 map3 区分,就会占用内存3个.产生不必要的内存.我的理解是这样的...
map每次使用在这里没必要重新new,key都相同,value会直接替换,直接只用一个map就好了
你可以写map1,map2,map3完全没问题,首先一个map,就是一个变量,变量map是放在栈里的,存的是new HashMap()的引用,new HashMap()
是放在堆里的,map在put完之后放入List了,这时变量map已经没用了,再给赋值一个new HashMap()可以重复利用,这样可以简洁代码,规范
,多次声明map1,map2map3显得多此一举。