分类: 算法与数据结构2011-10-19 10:53 5345人阅读 评论(0) 收藏 举报

1:使用HashMap的一个简单例子

  1. package com.pb.collection;
  2. import java.util.HashMap;
  3. import java.util.Iterator;
  4. import java.util.Set;
  5. import java.util.Map.Entry;
  6. public class HashMapDemo {
  7. public static void main(String[] args) {
  8. HashMap<String, String> hashMap = new HashMap<String, String>();
  9. hashMap.put("cn", "中国");
  10. hashMap.put("jp", "日本");
  11. hashMap.put("fr", "法国");
  12. System.out.println(hashMap);
  13. System.out.println("cn:" + hashMap.get("cn"));
  14. System.out.println(hashMap.containsKey("cn"));
  15. System.out.println(hashMap.keySet());
  16. System.out.println(hashMap.isEmpty());
  17. hashMap.remove("cn");
  18. System.out.println(hashMap.containsKey("cn"));
  19. //采用Iterator遍历HashMap
  20. Iterator it = hashMap.keySet().iterator();
  21. while(it.hasNext()) {
  22. String key = (String)it.next();
  23. System.out.println("key:" + key);
  24. System.out.println("value:" + hashMap.get(key));
  25. }
  26. //遍历HashMap的另一个方法
  27. Set<Entry<String, String>> sets = hashMap.entrySet();
  28. for(Entry<String, String> entry : sets) {
  29. System.out.print(entry.getKey() + ", ");
  30. System.out.println(entry.getValue());
  31. }
  32. }
  33. }

2:一个结合List和HashMap实现的例子

  1. import java.util.Iterator;
  2. import java.util.List;
  3. import java.util.HashMap;
  4. import java.util.ArrayList;
  5. import java.util.Map;
  6. import java.util.Scanner;
  7. import java.util.Set;
  8. import java.util.Map.Entry;
  9. /**
  10. * 在不创建学生类的情况下,从键盘输入n个学生信息(学号,姓名,年龄),
  11. * 输入完成后,打印出各个学生信息
  12. * @author ccna_zhang
  13. *
  14. */
  15. public class Assignment {
  16. public static void main(String[] args) {
  17. //定义保存学生信息的List,元素类型为HashMap
  18. List<HashMap<String, Object>> list = new ArrayList<HashMap<String, Object>>();
  19. Scanner input = new Scanner(System.in);
  20. System.out.println("请输入学生的信息,y表示继续,n表示退出");
  21. while("y".equals(input.next())) {
  22. HashMap<String, Object> map = new HashMap<String, Object>();
  23. System.out.println("请输入学号");
  24. map.put("studentno", input.next());
  25. System.out.println("请输入姓名");
  26. map.put("name", input.next());
  27. System.out.println("请输入年龄");
  28. map.put("age", input.nextInt());
  29. list.add(map);
  30. System.out.println("请继续输入学生的信息,y表示继续,n表示退出");
  31. }
  32. System.out.println("输入的学生信息为:");
  33. System.out.println("学生数量为:" + list.size());
  34. Iterator<HashMap<String, Object>> it = list.iterator();
  35. int i = 1;
  36. while(it.hasNext()) {
  37. HashMap<String, Object> stuMap = it.next();
  38. System.out.print("第" + i + "个学生的信息为");
  39. System.out.println("学号:" + stuMap.get("studentno") + " ,姓名:" + stuMap.get("name") + " ,年龄:" + stuMap.get("age"));
  40. }
  41. }
  42. }

Java中关于HashMap的使用和遍历(转)的更多相关文章

  1. Java中的HashMap的2种遍历方式比较

    首先我们准备数据,准备一个map Map<String, String> map = new HashMap<String, String>(); for (int i = 0 ...

  2. Java中关于HashMap的元素遍历的顺序问题

    Java中关于HashMap的元素遍历的顺序问题 今天在使用如下的方式遍历HashMap里面的元素时 1 for (Entry<String, String> entry : hashMa ...

  3. 沉淀再出发:java中的HashMap、ConcurrentHashMap和Hashtable的认识

    沉淀再出发:java中的HashMap.ConcurrentHashMap和Hashtable的认识 一.前言 很多知识在学习或者使用了之后总是会忘记的,但是如果把这些只是背后的原理理解了,并且记忆下 ...

  4. [转]为什么Java中的HashMap默认加载因子是0.75

    前几天在一个群里看到有人讨论hashmap中的加载因子为什么是默认0.75. HashMap源码中的加载因子 static final float DEFAULT_LOAD_FACTOR = 0.75 ...

  5. Java中的HashMap的工作原理是什么?

    问答题23 /120 Java中的HashMap的工作原理是什么? 参考答案 Java中的HashMap是以键值对(key-value)的形式存储元素的.HashMap需要一个hash函数,它使用ha ...

  6. Java 中 List 向前和向后遍历

    Java 中 List 向前和向后遍历 import java.util.*; public class TestCollectionIterator { public static void mai ...

  7. 关于Java中的HashMap的深浅拷贝的测试与几点思考

    0.前言 工作忙起来后,许久不看算法,竟然DFA敏感词算法都要看好一阵才能理解...真是和三阶魔方还原手法一样,田园将芜,非常可惜啊. 在DFA算法中,第一步是需要理解它的数据结构,在此基础上,涉及到 ...

  8. hash表及Java中的HashMap与HashSet

    链接: http://alex09.iteye.com/blog/539545/ 当程序试图将一个 key-value 对放入 HashMap 中时,程序首先根据该 key 的 hashCode() ...

  9. Java中的HashMap 浅析

    在Java的集合框架中,HashSet,HashMap是用的比较多的一种,顺序结构的ArrayList.LinkedList这种也比较多,而像那几个线程同步的容器就用的比较少,像Vector和Hash ...

随机推荐

  1. C++ 隐式类类型转换和转换操作符

    隐式类类型转换 C++语言定义了内置类型之间的几个自动转换.也可以定义如何将其他类型的对象隐式转换为我们的类类型,或将我们的类类型的对象隐式转换为其他类型.为了定义到类类型的隐式转换,需要定义合适的构 ...

  2. Chapter 2 Open Book——1

    The next day was better… and worse. 明天会更好也会更坏. It was better because it wasn't raining yet, though t ...

  3. csdn的调查问卷,好多都不懂哈

    http://bss.csdn.net/cview/reg/?project_id=2412&identy_id=1538

  4. QML中MouseArea元素的介绍

    原文:http://www.thisisqt.com/?action-viewnews-itemid-22 MouseArea元素的一个很典型的用法是和一个可视的item一起用,处理这个item的鼠标 ...

  5. spice-vdagent

    The spice-vdagent should be running in the guest. Have you installed the spice guest tools in your w ...

  6. javascript IP验证

    //IP验证function isIP(strIP){try{if(strIP.length<7){return false;}var re=/^(\d+)\.(\d+)\.(\d+)\.(\d ...

  7. 我眼中的C#3.0 摘自于网络:http://www.cnblogs.com/joinger/articles/1297237.html

    每次有新技术发布时,我们总能感受到两种截然不同的情绪: 一种是恐惧和抵抗,伴随着这种情绪的还有诸如"C# 2.0用的挺好的,为什么要在C# 3.0搞到那么复杂?"或者"我 ...

  8. SQL中的左连接与右连接有什么区别,点解返回值会不同?(转)

    例子,相信你一看就明白,不需要多说 A表(a1,b1,c1) B表(a2,b2) a1 b1 c1 a2 b2 01 数学 95 01 张三 02 语文 90 02 李四 03 英语 80 04 王五 ...

  9. Sql server 开窗函数over()的语法

    用法一:与ROW_NUMBER()函数结合用,给结果进行排序编号,如图: 代码如下: SELECT ROW_NUMBER() over(order by RequiredDate) num ,* fr ...

  10. JAVA-面向对象2--继承

    1. 继承的好处: 1.提高代码复用性. 2.让类与类之间产生关系,为面向对象的第三大特征 多态 提供了前提 2.java中支持单继承,不直接支持多继承,但对c++中多继承进行了改良.java通过多实 ...