java hashmap api_JAVA基础学习-集合三-Map、HashMap,TreeMap与常用API
一、Map简述
1.1、简述
public interface Map
类型参数:K - 此映射所维护的键的类型 keyV - 映射值的类型 value该集合提供键--值的映射。key不能重复,一对对的存储方式
将键映射到值的对象。一个映射不能包含重复的键;每个键最多只能映射到一个值。
1.2、方法
嵌套类摘要
static interface
方法摘要
void
boolean
true。
boolean
true。
boolean
null。
int
boolean
true。
Set 视图。
K key, V value)
将指定的值与此映射中的指定键关联(可选操作)。
void
Map extends K,? extends V> m)
从指定映射中将所有映射关系复制到此映射中(可选操作)。
int
1.3、常用子类
HashTable:底层是哈希表,不可以存入Null键Null值,线程是同步的JDK1.0效率低
HashMap:基于哈希表数据结构。允许使用Null键Null值,但只有一个Null键,线程非同步的。JDK1.2效率高
TreeMap:二叉树,线程不同步。可以用于给Map集中的key键进行排序。
和Sety集合很像,Set底层就是Map集合。
1.4、Put
添加元素,添加相同的键,那么后添加的值会覆盖的Vaule,put方法会返回被覆盖的值。
二、HashMap
2.1、常用方法
package com.pb.map.demo1;
import java.util.HashMap;
import java.util.Map;
public class MapDemo1 {
public static void main(String[] args) {
Map map=new HashMap();
//添加
map.put("01", "zhangsan");
System.out.println(map.put("01", "lisi002"));//zhangsan
map.put("02", "wangwu03");
map.put("03", "wangwu04");
map.put(null, "ffff");
map.put("04", "qqquqq");
//判断有没有key
System.out.println(map.containsKey("02"));//true
//判断 有这有 这个value
System.out.println(map.containsValue("ffff"));//true
//获取
System.out.println(map.get("03"));//wangwu04
System.out.println(map.get(null));//ffff
System.out.println(map.get("fdsfdsf"));//null
System.out.println(map.remove("02"));//返回value的值
System.out.println(map.remove("0fdsfd"));//没有就返回null
System.out.println(map);//{null=ffff, 01=lisi002, 03=wangwu04, 04=qqquqq} 是无序的
}
}
2.2、key和values
keySet:将map中所有的键 存入到Set集合。因为set具备迭代器。返回为set集合
可以迭代方式取出所有的键,在根据get方法,获取每一个键对应的值。
package com.pb.map.demo1;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;
public class MapDemo2 {
public static void main(String[] args) {
Map map=new HashMap();
//添加
map.put("09", "zhaoliu");
map.put("01", "zhangsan");
map.put("02", "wangwu03");
map.put("03", "wangwu04");
map.put("04", "qqquqq");
//获取map集合中的所有键的集合
Set keySet=map.keySet();
//迭代所有键来获取值
Iterator iterator=keySet.iterator();
while(iterator.hasNext()){
String key=iterator.next();
//通过map.get(键)的方式来获取值
System.out.println(key+".........."+map.get(key));
}
}
}
entrySet:返回为Set> entrySet:将Map集合中的映射关系存入到Set 集合中,而这个关系的数据类型就是Map.Entry
方法摘要
boolean
int
package com.pb.map.demo2;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;
/**
* 学生属性:姓名,年龄
* 注意姓名和年龄相同的视为同一个学生
* 1.描述学生
* 2.定义map容器,将学生做为键,地址作为值、值入
* 3.获取map集合的元素
*/
//学生类
class Student implements Comparable{
private String name;
private int age;
//让对象本身具备比较性
@Override
public int compareTo(Student s){
int num=new Integer(this.age).compareTo(new Integer(s.age));
if(num==0){
return this.name.compareTo(s.name);
}
return num;
}
/*
* 重写hash
*/
@Override
public int hashCode(){
return name.hashCode()+age*33;
}
/*
* 重写equals
*/
@Override
public boolean equals(Object obj){
if(!(obj instanceof Student)){
throw new ClassCastException("类型不匹配");
}
Student stu=(Student)obj;
return this.name.equals(stu.name)&&this.age==stu.age;
}
public Student() {
super();
}
public Student(String name, int age) {
super();
this.name = name;
this.age = age;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
public void show(){
System.out.println(this.name+"...."+this.age);
}
}
public class MapTest {
public static void main(String[] args) {
Map map=new HashMap();
map.put(new Student("lisi01",21), "北京");
map.put(new Student("lisi01",21), "上海");//覆盖第一个值
map.put(new Student("lisi02",23), "深圳");
map.put(new Student("lisi04",22), "武汉");
map.put(new Student("lisi03",24), "天津");
System.out.println("======keySet方法======");
//第一种遍历方式
Set keySet=map.keySet();
Iterator it=keySet.iterator();
while(it.hasNext()){
Student stu=it.next();
String add=map.get(stu);
System.out.println(stu.getName()+"..."+stu.getAge()+"...."+add);
}
System.out.println("======entrySet方法======");
//第二种遍历方式
Set> entrySet=map.entrySet();
Iterator> iter=entrySet.iterator();
while(iter.hasNext()){
Map.Entry student=iter.next();
Student stu=student.getKey();
String add=student.getValue();
System.out.println(stu.getName()+"..."+stu.getAge()+"...."+add);
}
}
}
======keySet方法======
lisi01...21....上海
lisi02...23....深圳
lisi04...22....武汉
lisi03...24....天津
======entrySet方法======
lisi01...21....上海
lisi02...23....深圳
lisi04...22....武汉
lisi03...24....天津
三、TreeMap
3.1、TreeMap排序
package com.pb.map.demo2;
import java.util.Comparator;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;
import java.util.TreeMap;
/**
* 学生属性:姓名,年龄
* 注意姓名和年龄相同的视为同一个学生
* 1.描述学生
* 2.定义map容器,将学生做为键,地址作为值、值入,
* 3.对学生排序按姓名排序
* 3.获取map集合的元素
*
*/
//学生类
class Student implements Comparable{
private String name;
private int age;
//让对象本身具备比较性
@Override
public int compareTo(Student s){
int num=new Integer(this.age).compareTo(new Integer(s.age));
if(num==0){
return this.name.compareTo(s.name);
}
return num;
}
/*
* 重写hash
*/
@Override
public int hashCode(){
return name.hashCode()+age*33;
}
/*
* 重写equals
*/
@Override
public boolean equals(Object obj){
if(!(obj instanceof Student)){
throw new ClassCastException("类型不匹配");
}
Student stu=(Student)obj;
return this.name.equals(stu.name)&&this.age==stu.age;
}
public Student() {
super();
}
public Student(String name, int age) {
super();
this.name = name;
this.age = age;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
public void show(){
System.out.println(this.name+"...."+this.age);
}
}
public class MapTest {
public static void main(String[] args) {
TreeMap map=new TreeMap(new StudentNameCom());
map.put(new Student("lisi01",21), "上海");//覆盖第一个值
map.put(new Student("lisi02",23), "深圳");
map.put(new Student("a",56), "北京");
map.put(new Student("lisi04",22), "武汉");
map.put(new Student("lisi03",24), "天津");
map.put(new Student("a",33), "北京");
map.put(new Student("lisi01",21), "北京");
System.out.println("======keySet方法======");
//第一种遍历方式
Set keySet=map.keySet();
Iterator it=keySet.iterator();
while(it.hasNext()){
Student stu=it.next();
String add=map.get(stu);
System.out.println(stu.getName()+"..."+stu.getAge()+"...."+add);
}
System.out.println("======entrySet方法======");
//第二种遍历方式
Set> entrySet=map.entrySet();
Iterator> iter=entrySet.iterator();
while(iter.hasNext()){
Map.Entry student=iter.next();
Student stu=student.getKey();
String add=student.getValue();
System.out.println(stu.getName()+"..."+stu.getAge()+"...."+add);
}
}
}
class StudentNameCom implements Comparator{
@Override
public int compare(Student stu1, Student stu2) {
int num=stu1.getName().compareTo(stu2.getName());
if(num==0){
return new Integer(stu1.getAge()).compareTo(new Integer(stu2.getAge()));
}
return num;
}
}
四、TreeMap使用
4.1、示例
package com.pb.map.demo2;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;
import java.util.TreeMap;
/*
* "sdfgzxcvasdfxcvdf"获取该字符串中的字母出次数
* 1.使用map集合映射
* 2.将字符中的字母做KEY,次数做value
*/
public class MapTest2 {
public static void main(String[] args) {
String str = "sdfgzxcvasdfxcvdf";
TreeMap map = getCount(str);
Set keySet = map.keySet();
Iterator it = keySet.iterator();
while (it.hasNext()) {
String s = it.next();
Integer count = map.get(s);
System.out.println(s + "...." + count);
}
String tmp = getCount2(str);
System.out.println(tmp);
}
// 第一种
public static TreeMap getCount(String str) {
TreeMap map = new TreeMap();
for (int x = 0; x < str.length(); x++) {
Set keys = map.keySet();
String s = str.substring(x, x + 1);
if (keys.contains(s)) {
Integer count = map.get(s);
map.put(s, count + 1);
} else {
map.put(s, 1);
}
}
return map;
}
// 第二种
public static String getCount2(String str){
//转换为字符数组
char[] chs=str.toCharArray();
//定义TreeMap容器来存放
TreeMap tm=new TreeMap();
//定义变量来存放次数
int count=0;
for(int x=0;x
if(!(chs[x]>='a' &&chs[x]<='z' || chs[x] >= 'A'&&chs[x]<='Z')){
continue;
}
Integer value=tm.get(chs[x]);
if(value!=null){
count=value;
}
count++;
tm.put(chs[x], count);
count=0;
}
//声明变长sb对象
StringBuilder sb=new StringBuilder();
//获取Map.Entry对象
Set> entrySet=tm.entrySet();
Iterator> it=entrySet.iterator();
//遍历添加
while(it.hasNext()){
Map.Entry m=it.next();
Character c=m.getKey();
Integer value=m.getValue();
sb.append(c+"("+value+")");
}
return sb.toString();
}
}
结果:
a....1
c....2
d....3
f....3
g....1
s....2
v....2
x....2
z....1
a(1)c(2)d(3)f(3)g(1)s(2)v(2)x(2)z(1)
五、Map扩展
5.1、Map中嵌套Map或者集合
package com.pb.map.demo3;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Iterator;
class Person{
private String name;
private int age;
public Person() {
super();
// TODO Auto-generated constructor stub
}
public Person(String name, int age) {
super();
this.name = name;
this.age = age;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
}
public class MapTest1 {
public static void main(String[] args) {
HashMap> map=new HashMap>();
ArrayList persons1=new ArrayList();
persons1.add(new Person("张三",33));
persons1.add(new Person("李四",33));
persons1.add(new Person("王五",33));
ArrayList persons2=new ArrayList();
persons2.add(new Person("赵六",33));
persons2.add(new Person("钱七",33));
persons2.add(new Person("刘八",33));
map.put("SB001", persons1);
map.put("SB002", persons2);
Iterator it=map.keySet().iterator();
while(it.hasNext()){
String room=it.next();
System.out.println(room);
ArrayList p=map.get(room);
getInfos(p);
}
}
public static void getInfos(ArrayList list){
Iterator it=list.iterator();
while(it.hasNext()){
Person p=it.next();
System.out.println(p.getName()+"..."+p.getAge());
}
}
}
//结果
SB001
张三...33
李四...33
王五...33
SB002
赵六...33
钱七...33
刘八...33
java hashmap api_JAVA基础学习-集合三-Map、HashMap,TreeMap与常用API相关推荐
- MySQL基础学习(三)————SQL语句的常用操作
文章目录 1.库 1.1库的创建 1.2 库的删除 1.3 库的修改 1.4 库的查找 2.表 2.1 表的创建 2.2 表的删除 2.3 表的修改 2.4 表的查找 3.数据或者记录 3.1 数据的 ...
- 【从零开始学Skynet】基础篇(三):服务模块常用API
1.服务模块 Skynet提供了开启服务和发送消息的API,必须要先掌握它们.列出了Skynet中8个最重要的API,PingPong程序会用到它们. Lua API 说明 newservice(na ...
- java入门基础学习(三)
文章目录 (一)有返回值的方法 (二)方法重载 习题 (一)有返回值的方法 格式:public static 返回值数据类型 方法名(参数){方法体return 数据;} 注意:1.返回值数据类型非v ...
- Mendix敏捷开发零基础学习《三》-高级 (数据删除保护机制、数据关联删除、Security安全、调用外部接口、调用JAVA代码)
目录 Mendix敏捷开发零基础学习<三> 一. 数据保护机制(Prevention of Delete) 1.业务需求 2.业务分析 3.项目实现 二.Mendix权限(Security ...
- Java高并发编程学习(三)java.util.concurrent包
简介 我们已经学习了形成Java并发程序设计基础的底层构建块,但对于实际编程来说,应该尽可能远离底层结构.使用由并发处理的专业人士实现的较高层次的结构要方便得多.要安全得多.例如,对于许多线程问题,可 ...
- Python基础学习笔记三
Python基础学习笔记三 print和import print可以用,分割变量来输出 import copy import copy as co from copy import deepcopy ...
- java线程之基础学习
java线程之基础学习总结 线程实现的两种方式: 在java中可以有两种方式实现多线程操作,一种是继承Thread类,另外一种是实现Runnable接口. 继承Thread类 Thread类是在jav ...
- JavaScript学习(三十三)—事件对象常用的属性和方法
JavaScript学习(三十三)-事件对象常用的属性和方法 (一).type属性 <style>#box {width: 200px;height:
- JavaScript学习(三十二)— Keycode常用键位码对照表
JavaScript学习(三十二)- Keycode常用键位码对照表 (一).字母和数字键的键码值(keyCode) (二).控制键键码值(keyCode) (三).多媒体键码值(keyCode)
最新文章
- Java / Android String.format 的使用
- HTML5新增的标签
- java uuid 效率_java uuid第一次性能
- Scrapy添加随机ip
- python入门第四章十大歌手 手机通讯录 神奇魔方阵 青春有你
- springcloud工作笔记095---springcloud项目后端验证_hibernate validator后端校验字段_自己实现_快速开发
- Python实现数据技术|爬虫便可获取免费百度文库付费文档
- matlab希尔伯特变换,基于matlab的Hilbert变换详解
- 白话区块链 之 11 - 区块链的链 是什么?
- 短信API接口怎么调用?
- Birt分类汇总报表(CUBES)空值转换为0
- 打开计算机读取硬盘慢,机械硬盘读写速度慢几招优化方法提升!
- python使用pypandoc将html转换成word文档
- LaTeX设置图片左对齐
- Smart3D系列教程4之 《案例实战演练1——小物件的照片三维重建》
- 项目十大管理(四)成本管理
- Python制作的简单易学的猜单词小游戏
- H3C(28)——IPSec
- 篇章级事件抽取任务拾遗
- c语言中一维数组和二维数组,详解C++中的一维数组和二维数组