关闭

从头认识java-9.10 Map

标签: java
1632人阅读 评论(0) 收藏 举报
分类:

这一章节我们来讨论一下Map。

Map就是“键值”关联数组。

1.演示

package com.ray.ch09;

import java.util.HashMap;
import java.util.Random;

public class Test {
	public static void main(String[] args) {
		HashMap<Integer, Integer> map = new HashMap<Integer, Integer>();
		Random random = new Random();
		for (int i = 0; i < 10; i++) {
			int key = random.nextInt(50);
			if (map.get(key) == null) {
				map.put(key, 1);
			} else {
				int value = map.get(key);
				map.put(key, value + 1);
			}
		}
		System.out.println(map.toString());
	}
}


输出:

{19=1, 38=1, 36=1, 37=1, 42=1, 10=1, 40=1, 41=1, 11=1, 45=1}

注意:由于我们上面的代码使用hashmap,因此它记录的结果是无序的,当我们下一次运行代码的时候,它们的顺序将会不一样。

 

2.常用方法containKeys和containValue

package com.ray.ch09;

import java.util.HashMap;
import java.util.Random;

public class Test {
	public static void main(String[] args) {
		HashMap<Integer, Integer> map = new HashMap<Integer, Integer>();
		Random random = new Random();
		for (int i = 0; i < 10; i++) {
			int key = random.nextInt(50);
			if (map.get(key) == null) {
				map.put(key, 1);
			} else {
				int value = map.get(key);
				map.put(key, value + 1);
			}
		}
		System.out.println(map.toString());
		System.out.println(map.containsKey(3));
		System.out.println(map.containsValue(5));
	}
}


输出:

{32=1, 18=1, 38=1, 5=1, 23=1, 6=1, 42=1, 43=1, 29=1, 15=1}
false
false

一般我们会使用上面的方法来测试map里面是否有我们想要的对象。

 

3.把数据发展到多维。

package com.ray.ch09;

import java.util.ArrayList;
import java.util.HashMap;

public class Test {
	public static void main(String[] args) {
		HashMap<Person, ArrayList<Pet>> map = new HashMap<Person, ArrayList<Pet>>();
		Person person = new Person();
		ArrayList<Pet> pets = new ArrayList<Pet>();
		for (int i = 0; i < 10; i++) {
			pets.add(new Pet());
		}
		map.put(person, pets);
	}
}

class Person {
}

class Pet {
}


上面的代码其实我们已经把数据机构变成了多维的形式。

 

总结:这一章节主要讲述了HashMap的使用。

 

这一章节就到这里,谢谢。

-----------------------------------

目录

 

0
1

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:909297次
    • 积分:14303
    • 等级:
    • 排名:第908名
    • 原创:494篇
    • 转载:0篇
    • 译文:2篇
    • 评论:282条
    博客专栏
    最新评论