从头认识java-9.10 Map
2015-11-19 22:28
525 查看
这一章节我们来讨论一下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和containValuepackage 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的使用。
这一章节就到这里,谢谢。-----------------------------------目录
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和containValuepackage 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的使用。
这一章节就到这里,谢谢。-----------------------------------目录
相关文章推荐
- java对世界各个时区(TimeZone)的通用转换处理方法(转载)
- java-注解annotation
- java-模拟tomcat服务器
- java-用HttpURLConnection发送Http请求.
- java-WEB中的监听器Lisener
- Android IPC进程间通讯机制
- Android Native 绘图方法
- Android java 与 javascript互访(相互调用)的方法例子
- 介绍一款信息管理系统的开源框架---jeecg
- 聚类算法之kmeans算法java版本
- java实现 PageRank算法
- PropertyChangeListener简单理解
- 插入排序
- 冒泡排序
- 堆排序
- 快速排序
- 二叉查找树
- [原创]java局域网聊天系统