不排序的Map

'不排序’的Map

需求:

不想插入的值按key (string) 排序, 而是按插入值的先后顺序放在容器中。

为实现这个目标,使用map轻易是做不出来的,所以我用List和Map结合实现结果集不排序:

	public static void main(String[] args) {
		List<String> list = new ArrayList<String>();

		String storeIn = "11,12,14,18,16,25,19,28";
		for (String store : storeIn.split(",")) {
			list.add(store);
		}

		Map<String, String> map = new HashMap<String, String>();
		for (int i = 10; i < 26; i++) {
			map.put("" + i, "读取" + i + "的数据存储");
		}
		for (int i = 0; i < list.size(); i++) {
			System.out.println(list.get(i) + "=" + (map.containsKey(list.get(i)) ? map.get(list.get(i)) : ""));
		}
	}

执行结果:

从中可以看到,18比16先插入“map集合”(实际先插入list集合),所以18在16前面打印。使用list的不排序,让不排序的key再从Map中获取对应的值。

思路:

map有什么?无非就是key和value,要不排序,当然要处理key,有没有不排序的东东代替key呢?有!List、Array、JSONArray都可以,那么能不能先把key存到这些不排序的东东,然后再在循环的时候去取结果集的对应value呢?如上测试所示,答案是可以的。

延伸:

那么,上面的代码也可以省略成:

	public static void main(String[] args) {

		String storeIn = "11,12,14,18,16,25,19,28";

		Map<String, String> map = new HashMap<String, String>();
		for (int i = 10; i < 26; i++) {
			map.put("" + i, "读取" + i + "的数据存储");
		}
		
		for (String store : storeIn.split(",")) {
			System.out.println(store + "=" + (map.containsKey(store) ? map.get(store) : ""));
		}
	}

又或者你不知道key列表的情况下:

	public static void main(String[] args) {
		Map<String, String> map = new HashMap<String, String>();
		int dataListSize = 10;    //假设是从数据库中查询得到的list结果集大小
		String[] storeIn = new String[dataListSize];
		for (int i = 0; i < dataListSize; i++) {
			storeIn[i] = "" + i;
			map.put("" + i, "读取" + i + "的数据存储");
		}
		for (String store : storeIn) {
			System.out.println(store + "=" + map.get(store));
		}
	}

怎么样,你看懂了吗?

附加:

同理,如果需要添加key不想排序的话,往List加key,再往结果集加数据就行啦!是不是很简单呢?

(如果使用数组,添加key时特别注意数组的大小哦!)


觉得可以,记得右上角点赞哦!如有不正确的地方,欢迎各位大神指教!

【The End】

猜你喜欢

转载自blog.csdn.net/m0_67391270/article/details/124465438