- 对于集合的应用在写程序的时候应用的还是很多的,集合在我看来是一个小小的缓存器,它可以存放一些数据,方便我们快速读出,集合在一定程度上加快了数据的读取速度,用两个小案例来体现一下集合的好处吧!
编写一个map集合存放手机号码,判断这个手机号码是否为中奖号码,把一个手机号
码,分割成三部分,如:123 1234 1234
这个手机号,需要把 123 作为第一个 key 把1234 作为第二个map的 key 最后四位作为
map的值,这里我已经将需求的操作简单概述了一下,那接下来我们看一下怎么操作的吧,
这里小编写了两篇,由刚开始的繁琐到最后的流畅版,接下来我们看一下吧!
//从文件中读取数据到数组进行读取分割判断
public static void mapPhone() throws IOException {
File file = new File("F:/phone.txt");
FileInputStream in = new FileInputStream(file);
BufferedInputStream bis = new BufferedInputStream(in);
byte[] buf = new byte[1024 * 4];
//list集合可以重复存入数据,不会把相同的数据覆盖掉,map遇到相同的键,会覆
掉原来的值,这里选择list集合比较合适
Map<String, List<Map<String, String>>> map = new HashMap<>();
String[] str = null;
int length = -1;
while ((length = bis.read(buf)) != -1) {
String s = new String(buf, 0, length);
// System.out.println(s);
str = s.split("\n");
}
// 把数据放入到map中
for (String s : str) {
Map<String, String> map1 = new HashMap<>();
List<Map<String, String>> list = new ArrayList<>();
System.out.println(s);
String key = s.substring(0, 3);
String key2 = s.substring(3, 7);
String value = s.substring(7, 11);
String s1 = "";
// 判断是否有相同主键的数据
if (map.containsKey(key)) {
list = map.get(key);
for (Map<String, String> listMap : list) {
if (listMap.containsKey(key2)) {
s1 = listMap.get(key2);
map1 = listMap;
}
}
}
l