>Java >java지도 시간 >Map&HashMapde에 대한 간략한 소개

Map&HashMapde에 대한 간략한 소개

零下一度
零下一度원래의
2017-07-23 17:44:021604검색

1. Map & HashMap 소개

1) Map 인터페이스

1 Map 인터페이스는 요소가 키-값 쌍의 형태로 저장되는 매핑 관계를 제공합니다. Key를 기준으로 빠르게 가치를 찾을 수 있습니다. 키-값은 어떤 객체라도 될 수 있으며 Entry 유형의 객체 인스턴스로 존재합니다.

2.Key는 반복될 수 없지만 Value는 반복될 수 있습니다. 키-값은 null일 수 있지만 하나의 키만 null일 수 있습니다.

3.Map은 일반 Map

4을 지원합니다. 각 키는 최대 하나의 값에만 매핑될 수 있습니다.

5.Map 인터페이스는 키 값 세트, 값 값 세트 및 항목(키)의 반환을 제공합니다. 값 쌍) 수집 방법

6. put을 통해 제거 피연산자

2) HashMap 구현 클래스

1. HashMap의 항목 개체는 순서 없이 정렬됩니다. Map의 중요한 구현 클래스이자 가장 일반적으로 사용되는 해시 테이블을 기반으로 구현됩니다

2. 키 값과 값 값 모두 null일 수 있지만 HashMap은 null 키 값을 가진 맵을 하나만 가질 수 있습니다. (키는 중복 불가) )


2. 학생 과목 선택 - Map을 활용하여 학생 추가

사례 기능 설명

1. Map를 통해 학생 정보 관리, 키는 학생 ID 그리고 가치는 학생의 객체입니다.

2. 키보드를 통해 학생 정보 입력

3. 컬렉션에 학생 정보 추가, 삭제, 확인

먼저 StuMap 클래스를 생성하여 Map 사용을 테스트합니다. 다음과 같습니다:

 1 /** 2  * 学生类的Map集合类 3  * 
 4  * @author acer 5  * 6  */ 7 public class StuMap { 8     // 用来承装学生类型对象 9     private Map<String, Student> students;10     private static Scanner in;11     {12         in = new Scanner(System.in);13     }14 15     public StuMap() {16         students = new HashMap<String, Student>();17 18     }19    //省略方法,下面的方法会逐个列出20 }

>>>>>>>>>>>>>> ;>>>>>>>>>>>>>>

는 지도 인터페이스에 객체를 추가하는 것과 다릅니다. put(key, value) 메소드. 다음은 사용 예입니다.

 1   /* 2      * 添加学生类 输入学生id, 3      * 判断是否被占用 若未被占用,则输入姓名,创建新的学生对象,并且把该对象添加到Map中 4      * 否则,则提示已有该id 5      */ 6     public void AddStu() { 7         System.out.println("请输入要添加的学生id:"); 8         String Id = in.next();// 接受输入的id 9         Student st=students.get(Id);10         if(st==null){11 12             System.out.println("请输入要添加的学生姓名:");13             String name = in.next();// 接受输入的name14             this.students.put(Id, new Student(Id, name));15         }else{16             System.out.println("此Id已被占用!");17         }18 19     }

다음과 같이 출력을 인쇄하는 테스트 함수를 작성합니다.

 1 /* 2      * 打印学生类 3      * 
 4      */ 5     public void PrintStu() { 6         System.out.println("总共有"+this.students.size()+"名学生:"); 7         //遍历keySet 8         for (String s : this.students.keySet()) { 9             Student st=students.get(s);10             if(st!=null){11             System.out.println("学生:" + students.get(s).getId() + "," + students.get(s).getName());12             }13         }14     }

위 예에서는 Map의 keySet()을 사용하여 Map을 사용한 다음 if를 사용하여 출력을 판단하려면 Map에서 entrySet() 메서드를 사용하여 키-값 쌍을 반환할 수도 있습니다. Entry in the Map, 예:

 1 /* 2      * 通过entrySet方法遍历Map 3      */ 4     public void EntrySet(){ 5         Set<Entry<String, Student>> entrySet =students.entrySet(); 6         for(Entry<String, Student> entry:entrySet){ 7             System.out.println("取得建:"+entry.getKey()); 8             System.out.println("对应的值:"+entry.getValue().getName()); 9 10         }11     }

마지막으로 우리는 메인 함수를 호출하여 효과를 확인하세요

1 public static void main(String[] args) {2         StuMap stu = new StuMap();3         for (int i = 0; i < 3; i++) {4             stu.AddStu();5         }6         stu.PrintStu();7         stu.EntrySet();8     }

코드 분석:

1.student.get(ID)는 Map의 get() 메소드를 사용하여 값이 ID인 학생이 있는지 여부를 감지합니다. null을 반환합니다. 이 경우는 Map에 있는 키 값을 학생의 ID 값으로 설정해서 이런 식으로 감지할 수 있도록 하는 것인데, 그 키 값이 학생의 다른 속성이라면 얘기가 달라지겠죠! !

2.keySet() 메서드는 모든 키의 Set 컬렉션을 반환합니다.

3.keyset()은 Set 컬렉션에서 수신할 수 있는 세트 형식으로 Map의 모든 키를 반환합니다. HashMap의 매핑은 순서가 없습니다.

3.Map은 key-value 쌍을 반환하기 위해 EntrySet() 메소드를 사용할 수도 있습니다. Entry는 Set 컬렉션이기도 합니다. 키-값 쌍은 각각 " key” 및 “value입니다. 실행 결과:

3. 학생 과목 선택 - Map에서 학생 삭제


Map에서 키-값 쌍을 삭제하려면 제거(객체 키) 메소드를 호출하는 방법이 있으며, 다음은 예시입니다. 용도:

 1 /* 2      * 删除map中映射 3      */ 4     public void RemoveStu(){ 5         do{ 6         System.out.println("请输入要删除的学生id:"); 7         String Id = in.next();// 接受输入的id 8         Student st=students.get(Id); 9         if(st==null){10             System.out.println("此id不存在!");11             12         }else{13             this.students.remove(Id);14             System.out.println("成功删除"+st.getId()+","+st.getName()+"同学");15             break;16         }17         }while(true);18     }

실행 결과:

4. 학생 강좌 선택 - 맵에서 학생 수정


맵에서 키-값 쌍을 수정하는 방법에는 두 가지가 있습니다.

put 메소드

를 사용합니다. 실제로는 add 메소드에 넣는다. 사용법은 add와 동일하다. 여기서의 본질은 원본 데이터를 덮어쓰는 것, 즉 수정하는 것이다.

 1 /* 2      * 利用put方法修改Map中的value值 3      */ 4     public void ModifyStu(){ 5         do{ 6             System.out.println("请输入要修改的学生id:"); 7             String Id = in.next();// 接受输入的id 8             Student st=students.get(Id); 9             if(st==null){10                 System.out.println("此id不存在!");11                 12             }else{13                 System.out.println("学生原来的姓名:"+st.getName()+",请输入修改后的姓名:");14                 String name = in.next();// 接受输入的name15                 st=new Student(Id,name);16                 this.students.put(Id,st);17                 System.out.println("成功修改!修改后的学生为:"+st.getId()+","+st.getName()+"同学");18                 break;19             }20             }while(true);21         22     }
Map은 put 메소드 외에도 대체라는 메소드를 제공합니다. 교체 메소드는 내부 소스 코드가 다음과 같기 때문에 put 메소드와 동일하게 사용됩니다.

1 if (map.containsKey(key)) {2      return map.put(key, value);3  } else4      return null;5

可以看出replace方法就是调用put方法来完成修改操作的,但是我们为了和添加put进行区分,最好在使用修改的时候用replace方法进行修改。这样的代码可读性和维护性就增强了。

那么使用replace修改Map中的value值如下:(推荐使用replace方法)

 1 /* 2      * 利用replace方法修改Map中的value值 3      */ 4     public void Modify(){ 5         do{ 6             System.out.println("请输入要修改的学生id:"); 7             String Id = in.next();// 接受输入的id 8             Student st=students.get(Id); 9             if(st==null){10                 System.out.println("此id不存在!");11                 12             }else{13                 System.out.println("学生原来的姓名:"+st.getName()+",请输入修改后的姓名:");14                 String name = in.next();// 接受输入的name15                 st=new Student(Id,name);16                 this.students.replace(Id, st);17                 System.out.println("成功修改!修改后的学生为:"+st.getId()+","+st.getName()+"同学");18                 break;19             }20             }while(true);21     }

运行结果:


五、总结

Map -特点:元素成对出现,key-value,是映射关系,key不能重复,但value可以重复,也就是说,可以多key对一个value。支持泛型如Map

-实现类:HashMap是最常用的,HashMap中是无序排列,其元素中key或value可为null(但只能有一个为null)。

-声明(泛型)举例: 在类中声明 public Map<类型1, 类型2> xxx; 然后再构造方法中this.xxx = new HashMap<类型1, 类型2();

-获取:yy temp = xxx.get(key)

-添加:xxx.put( key(xx型), zz(yy型) );

-返回map中所有key(返回是set型集合形式) set xxxxx = xxx.keyset(); 用于遍历。

-返回map中所有entry对(key-value对)(返回是set型集合形式) set> xxxxx = xxx.entrySet(); 同样用于遍历。 遍历时:for(Entry 元素: xxxxx)

-删除:xxx.remove(key);

-修改可以用put,当put方法传入的key存在就相当于是修改(覆盖);但是推荐使用replace方法!

위 내용은 Map&HashMapde에 대한 간략한 소개의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.