Map是以键值对(key-value)的形式来存储数据的。而且Map不允许key的重复,通过Map存储key-value对时,只需要考虑key的存储就可以,key存储后value就会跟着key(完全可以把value当前key的"附庸舞")。

注意:如果只管Map里边的key,并把所有的key都手机起来那就变成set了。Map与set是一一对应的。

 1、Hashset底层是靠HashMap来实现的,HashMap用"hash"算法控制"一个萝卜一个坑"来进行快速存储;

 2、TreeSet底层是靠TreeMap来实现的,TreeMap就是真正的"红黑树";

 3、Hashtable线程是安全的(实现不好,性能低),HashMap是线程不安全的(但可以通过collections工具类来提升安全),HashMap性能要好些,除此之外Hashtable与HashMap几乎一样。

Map对key是有要求的:

 1、HashMap对key的要求:

  HashMap是根据key的hashCode()方法的返回值来计算key的存、取位置。

  那HashMap怎样才算两个key重复呢?

   ①、通过eqauls()方法比较返回true;

   ②、两个key的hashCode()返回值相等。

 import java.util.*;

 public class HashMapTest{
public static void main(String[] args){
//HashMap只考虑key的存储,它对key的存储机制,几乎与HashSet的机制相同,add每放一次都仅一个值,put可放key-value对
//如果希望HashMap记住我们添加元素的顺序,应该考虑使用LinkedHashMap
HashMap<String,double> test = new HashMap<>(); //对于Map而言,每次添加都要key-value对
test.put("语文",88.0);
test.put("数学",99.0);
test.put("英语",78.0); System.out.println(test.size());
System.out.println(test);
}
}
 import java.util.*;

 class Person{
private String name;
private double height;
public Person(String name, double height){
this.name = name;
this.height = height;
} @Override
public String toString(){
return "他/她是:" + name + "身高是:" + height;
} @Override
public boolean equals(Object obj){
if(this == obj){
return true;
}
//判断关键属性是否相等
if(obj != null && obj.getClass() == Person.class){
Person p = (Person)obj;
return this.height = p.height && this.name.equals(p.name);
}
return false;
} @Override
public int hashCode(){
return name.hashCode() + 10*(int)height;
}
} public class TestHashMap{
public static void main(String[] args){
HashMap<Person,double> hs = new HashMap<>(); hs.put(new Person("James",180),77);
hs.put(new Person("Polo",171),76);
hs.put(new Person("James",180),77); System.out.println(hs);
}
}

 2、TreeMap对key的要求:

  TreeMap底层的红黑树只对key进行排序,并且要求key必须是可比较大小的。TreeMap和TreeSet一样同样有两 种排序方法:

   ①、自然排序:要求所有key实现Comparable接口/(自定义的必须手动实现、默认已实现(API)的直接调用即可);

   ②、定制排序:要求创建TreeMap时提供一个Comparator对象

   那TreeMap怎样才算两个key重复呢?

    通过Compare()方法比较大小返回0时,则表明两个元素是相等的。

 public class TreeMapTest{
public static void main(String[] args){
//如果创建TreeMap时没有传入Comparator对象,说明用的是自然排序
//因为String已经实现了Comparable接口
TreeMap<String , Double> test = new TreeMap<>(); //对于Map而言,每次添加都要key-value对
test.put("aaa",88.0);
test.put("abc",99.0);
test.put("xyz",78.0); System.out.println(test);
}
}

查看/遍历Map方法:

 遍历Map有以下三种方法:

  遍历所有键值对: entrySet()

  遍历所有key: keySet()

  遍历所有value: values()

JDK1.7后基本都是用第二种方法进行遍历,因为第二种方法性能是最好的,下面链接文章进行了详细比较:

http://www.cnblogs.com/fczjuever/archive/2013/04/07/3005997.html

 set和Map遍历的情况是一样的:都可以用for循环和迭代器进行遍历。

 import java.util.*;

 class TestForMap {
public static void main(String[] args){
HashMap<String, String> hp = new HashMap<String, String>();
hp.put("username","hp");
hp.put("password","12345");
hp.put("email","hp@hp.com");
hp.put("UserID","358"); //keySet()方式使用for循环遍历Map
for(String key : hp.keySet()){
//循环遍历Map的key值
System.out.println(key);
//循环遍历Map中key对应的value值
//System.out.println(hp.get(key));
} Iterator<String> it = hp.keySet().iterator();
while(it.hasNext()){
//循环遍历Map的key值
//System.out.println(it.next());
//循环遍历Map中key对应的value值
System.out.println(hp.get(it.next()));
}
}
}

疯狂java笔记(七) - Java集合之Map的更多相关文章

  1. 转 Java笔记:Java内存模型

    Java笔记:Java内存模型 2014.04.09 | Comments 1. 基本概念 <深入理解Java内存模型>详细讲解了java的内存模型,这里对其中的一些基本概念做个简单的笔记 ...

  2. Java笔记:Java集合概述和Set集合

    本文主要是Java集合的概述和Set集合 1.Java集合概述 1)数组可以保存多个对象,但数组长度不可变,一旦在初始化数组时指定了数组长度,这个数组长度就是不可变的,如果需要保存数量变化的数据,数组 ...

  3. java第七章集合框架

    如果想存储多个人物信息可以使用数组实现但是采用数组存以下明显缺陷: 数组长度不变不能适应元素变化情况,若存储大于20个英雄信息则长度不够,若只存储10个则造成内存空间浪费.可用.length获取数组中 ...

  4. Java(28)集合三Map

    作者:季沐测试笔记 原文地址:https://www.cnblogs.com/testero/p/15228436.html 博客主页:https://www.cnblogs.com/testero ...

  5. java 笔记(4) —— java I/O 流、字节流、字符流

    Java中使用流来处理程序的输入和输出操作,流是一个抽象的概念,封装了程序数据于输入输出设备交换的底层细节.JavaIO中又将流分为字节流和字符流,字节流主要用于处理诸如图像,音频视频等二进制格式数据 ...

  6. Java笔记:Java 流(Stream)、文件(File)和IO

    更新时间:2018-1-7 12:27:21 更多请查看在线文集:http://android.52fhy.com/java/index.html java.io 包几乎包含了所有操作输入.输出需要的 ...

  7. 菜鸡的Java笔记 简单JAVA 类的开发原则以及具体实现

    /*  现在要求定义一个雇员信息类 在这个类之中包含有雇员编号 姓名 职位 基本工资 佣金等信息    对于此时给定要求实际上就是描述一类事物,而这样的程序类在在java之中可以将其称为简单java类 ...

  8. Java 学习笔记 两大集合框架Map和Collection

    两大框架图解 Collection接口 由第一张图,我们可以知道,Collection接口的子接口有三种,分别是List接口,Set接口和Queue接口 List接口 允许有重复的元素,元素按照添加的 ...

  9. Java基础学习笔记七 Java基础语法之继承和抽象类

    继承 继承的概念 在现实生活中,继承一般指的是子女继承父辈的财产.在程序中,继承描述的是事物之间的所属关系,通过继承可以使多种事物之间形成一种关系体系. 例如公司中的研发部员工和维护部员工都属于员工, ...

随机推荐

  1. 单击双击手势(UITapGestureRecognizer)

    - (void)viewDidLoad { [super viewDidLoad]; // Do any additional setup after loading the view, typica ...

  2. 解决eclipse manven项目添加不了maven dependencis

    <classpathentry kind="con" path="org.eclipse.m2e.MAVEN2_CLASSPATH_CONTAINER"& ...

  3. NYOJ题目806HEIHEI的心情

    aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAAtMAAANRCAIAAACumacBAAAgAElEQVR4nOzdrXLrOrjG8XMT5b2Q4l

  4. 学习JNDI

    既然datasource对象有tomcat提供,那么我们如何在应用程序中获得它呢,tomcat把这个对象放在JNDI服务中, 并用一个名字把它关联起来,我们在应用程序中,只需通过JNDI搜索这个名字, ...

  5. php的错误级别

    error_reporting() 用于设置 PHP 的报错级别并返回当前级别.(PHP 4, PHP 5) 函数能够在运行时设置 error_reporting 指令. PHP 有诸多错误级别,使用 ...

  6. php 复习

    <?php 一.php基础语法1.输出语句:echo print print_r var_dump() 2.php是弱类型语言强制转换类型: (类型)变量 settype(变量,类型) 3.变量 ...

  7. linux中who命令显示的tty、pts和(:0)(:0.0)是什么意思

    http://blog.csdn.net/cwj_beyond/article/details/6987345 http://unix.stackexchange.com/questions/7217 ...

  8. Android浏览本地 API文档 + 解决页面加载慢的问题

    火狐浏览器安装离线浏览插件: 用浏览器打开index.html文件,你会发现加载的很慢,原因你懂的,为此,我们可以通过离线的方式 查看本地API文档,用火狐浏览器  +   Work Offline插 ...

  9. 【JAVA反射机制】

    一.Class类 Java.lang.Object |-java.lang.Class<T> 构造方法:无. 常用方法: static Class<?> forName(Str ...

  10. Power BI for Office 365介绍

    微软在七月份发布了一个新产品,它建立在微软的云的第一个数据平台- Power BI for Office 365.Satya Nadella,服务器和工具业务总裁,在当天的上午在微软的年度全球合作伙伴 ...