map集合修改其中元素

package com.swift.lianxi;

import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;

/*1.请简述Map 的特点
2.请简述HashMap的特点
3.请简述LinkedHashMap的特点
4.使用代码依次完成:
    a).将如下键值对信息存入Map集合中:
        "黄晓明", "Baby"
        "邓超", "孙俪"
        "李晨", "范冰冰"
        "大黑牛", "范冰冰"
    b).将"李晨"对应的值替换成"白百合"
    c).获取"大黑牛"对应的值,如果是"范冰冰"就删除以"大黑牛"为键的元素

5.使用代码完成:往一个Map集合中添加若干元素.获取Map中的所有key, 并使用增强for和迭代器遍历输出每个key
6.使用代码完成:往一个Map集合中添加若干元素.获取Map集合中所有的键值对(Entry)对象, 并使用增强for和迭代器遍历输出每个key和value
7.使用代码完成:将学员的信息作为元素存入HashMap中,
    提示:1.每位学生(姓名,年龄)都有自己的家庭住址
        2.将学生对象和家庭住址存储到map集合中。学生作为键, 家庭住址作为值。
         3.学生姓名相同并且年龄相同视为同一名学生*/

public class Demo1 {

    public static void main(String[] args) {

        HashMap<String, String> map = new HashMap<String,String>();
        map.put("黄晓明", "Baby");
        map.put("邓超", "孙俪");
        String str1=map.put("李晨", "范冰冰");
        map.put("大黑牛", "范冰冰");
        System.out.println(map);
        //如果键值相同,直接put就是替换
        String str2=map.put("李晨", "白百合");
        System.out.println(map);
        System.out.println(str1+"..."+str2);
        String str3=map.get("大黑牛");
        if("范冰冰".equals(str3)) {
            map.remove("大黑牛");
        }
        System.out.println(map);

        System.out.println("===========================================");
        //keySet使用增强for遍历
        Set<String> keys = map.keySet();
        for(String key:keys) {
            System.out.println(key+"..."+map.get(key));
        }
        //keySet使用iterator遍历
        System.out.println("===========================================");
        Set<String> set =map.keySet();
        Iterator<String> it=set.iterator();
        while(it.hasNext()) {
            String name = it.next();
            System.out.println(name+"..."+map.get(name));
        }
        //entrySet使用增强for遍历
        System.out.println("===========================================");
        Set<Map.Entry<String,String>> entry = map.entrySet();
        for(Map.Entry<String, String> key:entry) {
            System.out.println(key.getKey()+"..."+key.getValue());
        }
        //entrySet使用iterator遍历
        System.out.println("===========================================");
        Set<Map.Entry<String,String>> set1 =map.entrySet();
        Iterator<Map.Entry<String,String>> it1=set1.iterator();
        while(it1.hasNext()) {
            Map.Entry<String,String> entry1= it1.next();
            System.out.println(entry1.getKey()+"..."+entry1.getValue());
        }

        HashMap<Student, String> students = new HashMap<Student,String>();
        students.put(new Student("zhangsan",20), "北京");
        students.put(new Student("lisi",21), "上海");
        students.put(new Student("wangwu",22), "广州");
        students.put(new Student("zhaoliu",23), "深圳");
        students.put(new Student("zhaoliu",23), "香港");
        for(Student stu:students.keySet()) {
            System.out.println(stu.toString()+"..."+students.get(stu));
        }
    }

}

class Student{

    private String name;
    private int age;
    private String address;
    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 String getAddress() {
        return address;
    }
    public void setAddress(String address) {
        this.address = address;
    }
    public Student(String name, int age, String address) {
        super();
        this.name = name;
        this.age = age;
        this.address = address;
    }
    public Student(String name, int age) {
        super();
        this.name = name;
        this.age = age;
    }
    public Student() {
        super();
        // TODO Auto-generated constructor stub
    }
    @Override
    public int hashCode() {
        final int prime = 31;
        int result = 1;
        result = prime * result + ((address == null) ? 0 : address.hashCode());
        result = prime * result + age;
        result = prime * result + ((name == null) ? 0 : name.hashCode());
        return result;
    }
    @Override
    public boolean equals(Object obj) {
        if (this == obj)
            return true;
        if (obj == null)
            return false;
        if (getClass() != obj.getClass())
            return false;
        Student other = (Student) obj;
        if (address == null) {
            if (other.address != null)
                return false;
        } else if (!address.equals(other.address))
            return false;
        if (age != other.age)
            return false;
        if (name == null) {
            if (other.name != null)
                return false;
        } else if (!name.equals(other.name))
            return false;
        return true;
    }
    @Override
    public String toString() {
        return "Student [name=" + name + ", age=" + age + ", address=" + address + "]";
    }

}

原文地址:https://www.cnblogs.com/qingyundian/p/8495079.html

时间: 2024-11-07 15:04:27

map集合修改其中元素的相关文章

黑马程序员——Java基础---集合(二)------Map集合

------<a href="http://www.itheima.com" target="blank">Java培训.Android培训.iOS培训..Net培训</a>.期待与您交流! ------- Map集合 一.概述 1.简述: Map<K,V>集合是一个接口,和List集合及Set集合不同的是,它是双列集合,并且可以给对象加上名字,即键(Key) 2.特点: 1)该集合存储键值对,一对一对往里存 2)要保证键的唯一性

I学霸官方免费教程三十三:Java集合框架之Map集合

Map接口 Map集合采用键值对(key-value)的方式存储数据,其中键不可以重复.值可以重复. 常用类有HashMap.TreeMap和Properties HashMap类 假如,现在我有一个集合,集合中存储着一批WiFi的名称和密码,现在要求通过名称快速找到密码.这样的需求使用List集合实现起来非常困难,Java为我们提供了另一种形式的集合,可以很好的解决这样的问题.就是Map集合. 实例: package map.hashMap; import java.util.HashMap;

黑马程序员——黑马基础——Map,集合框架工具类Conlections和Arrays

黑马程序员--黑马基础--Map,集合框架工具类Conlections和Arrays ------Java培训.Android培训.iOS培训..Net培训.期待与您交流! ------- 一,Map集合 Map<K,V>集合是一个接口,和List集合及Set集合不同的是,它是双列集合,并且可以给对象加上名字,即键(Key). 特点: 1)该集合存储键值对,一对一对往里存 2)要保证键的唯一性. Map集合的子类 Map |--Hashtable:底层是哈希表数据结构,不可以存入null键nu

黑马程序员-----集合框架类(三) Map集合

黑马程序员-----集合框架类(三) Map集合 1.1 Map集合:该集合存储键值对.一对一对往里存.而且要保证键的唯一性. 1,添加. put(K key, V value) putAll(Map<? extends K,? extends V> m) 2,删除. clear() remove(Object key) 3,判断. containsValue(Object value) containsKey(Object key) isEmpty() 4,获取. get(Object ke

java中Map集合的理解

Map |--Hashtable:底层是哈希表数据结构,不可以存入null键null值.该集合是线程同步的.jdk1.0.效率低. |--HashMap:底层是哈希表数据结构,允许使用 null 值和 null 键,该集合是不同步的.将hashtable替代,jdk1.2.效率高. |--TreeMap:底层是二叉树数据结构.线程不同步.可以用于给map集合中的键进行排序. 和Set很像.其实大家,Set底层就是使用了Map集合. /* map集合的两种取出方式: 1,Set<k> keySe

有序取出Map集合的元素(自写无喷)

最近写到一个程序,返回了map,但是经过查阅资料,map是没有顺序的,各种查阅资料无果,最后自己写了这个方法.. 1,通过map集合的keySet()方法,获取到一个包含map所有key的Set集合 2,定义一个新的TreeSet集合(TreeSet集合有自动排序功能) 3,将第一步得到的Set集合遍历赋给TreeSet集合,这样所有key都排好序并保存在TreeSet里面 4,然后通过TreeSet的迭代器遍历,并同时根据迭代器返回的key,一个一个取出map里面的value --------

Map集合框架的使用

Map用于保存具有映射关系的数据(key-vlaue).Map的key不允许重复,即同一个Map对象的任何两个key通过equals方法比较总是返回false Map中包含了一个keySet()方法,用于返回Map所以key组成的Set集合. Map集合与Set集合元素的存储形式很像,如Set接口下有HashSet.LinkedHashSet.SortedSet(接口).TreeSet.EnumSet等实现类和子接口,而Map接口下则有HashMap.LinkedHashMap.SortedMa

day07(Set接口,HashSet类,hashcoad(),Collections工具类,Map集合)

Set接口 set接口的实现类特点 1.无序(取出来的顺序和存进去的数据的顺序不一致) 2.唯一(数据不能存相同的) 底层是用Map集合写的 HashSet类  实现了  set接口       唯一性  public class HashSetTest { public static void main(String[] args) { HashSet<String> hs=new HashSet<String>(); hs.add("hello"); hs.

ES6中的Set和Map集合

前面的话 在ES6标准制定以前,由于可选的集合类型有限,数组使用的又是数值型索引,因而经常被用于创建队列和栈.如果需要使用非数值型索引,就会用非数组对象创建所需的数据结构,而这就是Set集合与Map集合的早期实现.本文将详细介绍ES6中的set和map集合 引入 Set集合是一种无重复元素的列表,开发者们一般不会逐一读取数组中的元素,也不太可能逐一访问Set集合中的每个元素,通常的做法是检测给定的值在某个集合中是否存在 Map集合内含多组键值对,集合中每个元素分别存放着可访问的键名和它对应的值,