Java集合的Stack、Queue、Map的遍历

一、Map的遍历

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

/** 
* Map的遍历,这个遍历比较特殊,有技巧 
* 
* @author leizhimin 2009-7-22 15:15:34 
*/ 
public class TestMap { 
        public static void main(String[] args) { 
                Map<String, String> map = new HashMap<String, String>(); 
                map.put("1", "a"); 
                map.put("2", "b"); 
                map.put("3", "c"); 

                //最简洁、最通用的遍历方式 
                for (Map.Entry<String, String> entry : map.entrySet()) { 
                        System.out.println(entry.getKey() + " = " + entry.getValue()); 
                } 
                //Java5之前的比较简洁的便利方式1 
                System.out.println("----1----"); 
                for (Iterator<Map.Entry<String, String>> it = map.entrySet().iterator(); it.hasNext();) { 
                        Map.Entry<String, String> entry = it.next(); 
                        System.out.println(entry.getKey() + " = " + entry.getValue()); 
                } 
                //Java5之前的比较简洁的便利方式2 
                System.out.println("----2----"); 
                for (Iterator<String> it = map.keySet().iterator(); it.hasNext();) { 
                        String key = it.next(); 
                        System.out.println(key + " = " + map.get(key)); 
                } 
        } 
}

3 = c 
2 = b 
1 = a 
----1---- 
3 = c 
2 = b 
1 = a 
----2---- 
3 = c 
2 = b 
1 = a 
Process finished with exit code 0


二、Queue的遍历

import java.util.Queue; 
import java.util.concurrent.LinkedBlockingQueue; 

/** 
* 队列的遍历 
* 
* @author leizhimin 2009-7-22 15:05:14 
*/ 
public class TestQueue { 
        public static void main(String[] args) { 
                Queue<Integer> q = new LinkedBlockingQueue<Integer>(); 
                //初始化队列 
                for (int i = 0; i < 5; i++) { 
                        q.offer(i); 
                } 
                System.out.println("-------1-----"); 
                //集合方式遍历,元素不会被移除 
                for (Integer x : q) { 
                        System.out.println(x); 
                } 
                System.out.println("-------2-----"); 
                //队列方式遍历,元素逐个被移除 
                while (q.peek() != null) { 
                        System.out.println(q.poll()); 
                } 
        } 
}


-------1----- 





-------2----- 





Process finished with exit code 0


三、Stack的遍历

import java.util.Stack; 

/** 
* 栈的遍历 
* 
* @author leizhimin 2009-7-22 14:55:20 
*/ 
public class TestStack { 
        public static void main(String[] args) { 
                Stack<Integer> s = new Stack<Integer>(); 
                for (int i = 0; i < 10; i++) { 
                        s.push(i); 
                } 
                //集合遍历方式 
                for (Integer x : s) { 
                        System.out.println(x); 
                } 
                System.out.println("------1-----"); 
                //栈弹出遍历方式 
//                while (s.peek()!=null) {     //不健壮的判断方式,容易抛异常,正确写法是下面的 
                while (!s.empty()) { 
                        System.out.println(s.pop()); 
                } 
                System.out.println("------2-----"); 
                //错误的遍历方式 
//                for (Integer x : s) { 
//                        System.out.println(s.pop()); 
//                } 
        } 
}







------1----- 





------2----- 
Process finished with exit code 0


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Java中的集合主要分为List、Set、Map三种类型。其中List是按照元素的插入顺序有序存储的集合,Set是不允许有重复元素存在的集合,而Map则是以键值对的形式存储元素。Java提供了各种集合类的实现,如ArrayList、LinkedList、HashSet、TreeSet、HashMap、TreeMap等。同时,Java 8还引入了Stream API,使得集合操作具有函数式编程的特点,方便开发人员进行快速、简洁、高效的数据处理。 ### 回答2: 在Java中,有许多不同类型的集合可供使用。以下是常见的Java集合: 1. List(列表):List是一个有序的集合,可以包含重复的元素。Java中的List接口有很多实现类,如ArrayList和LinkedList。 2. Set(集合):Set是一个不允许包含重复元素的集合Java中的Set接口有很多实现类,如HashSet和TreeSet。 3. Map(映射):Map是一种将键和值关联起来的集合Java中的Map接口有很多实现类,如HashMap和TreeMap。 4. Queue(队列):Queue是一种先进先出(FIFO)的数据结构。Java中的Queue接口有很多实现类,如LinkedList和PriorityQueue。 5. Stack(栈):Stack是一种后进先出(LIFO)的数据结构。Java中的Stack类实现了栈的功能。 除了以上常用的集合类型,Java还提供了许多其他集合类型,如SortedSet、SortedMap、HashSet、LinkedHashSet等。这些集合类型都在Java集合框架中定义,并提供了丰富的操作和方法,方便我们进行元素的添加、删除、搜索等操作。 总之,Java中的集合类提供了一种灵活和高效的方式来处理和操作一组元素。我们可以根据实际需要选择适合的集合类型来存储和处理数据。 ### 回答3: 在Java中,集合是用来存储和操作一组对象的数据结构。Java提供了许多集合类来满足不同的需求。 常见的Java集合类有: 1. ArrayList:动态数组,可以根据需要自动扩展大小。 2. LinkedList:链表,可以高效地进行插入和删除操作。 3. HashSet:基于哈希表的集合,不允许重复元素。 4. TreeSet:基于红黑树的有序集合,元素按照自然顺序进行排序。 5. HashMap:基于哈希表的键值对映射,不允许重复键。 6. TreeMap:基于红黑树的有序键值对映射,按照键的自然顺序进行排序。 7. LinkedHashMap:基于哈希表和双向链表的键值对映射,保持插入顺序。 8. Queue:队列接口,按照先进先出(FIFO)的原则进行元素访问。 9. Stack:栈接口,按照后进先出(LIFO)的原则进行元素访问。 这些集合类都是Java集合框架的一部分,通过使用它们,可以方便地进行元素的添加、删除、遍历等操作。根据实际需求,可以选择合适的集合类来存储和处理数据。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值