1.LinkedList的遍历方式
a.一般的for循环(随机访问)
- int size = list.size();
- for (int i=0; i<size; i++) {
- list.get(i);
- }
b.for--each循环
- for (Integer integ:list)
- ;
c.迭代器iterator
- for(Iterator iter = list.iterator(); iter.hasNext();)
- iter.next();
d.用pollFirst()来遍历LinkedList
- while(list.pollFirst() != null)
- ;
e.用pollLast()来遍历LinkedList
- while(list.pollLast() != null)
- ;
f.用removeFirst()来遍历LinkedList
- try {
- while(list.removeFirst() != null)
- ;
- } catch (NoSuchElementException e) {
- }
g.用removeLast()来遍历LinkedList
- try {
- while(list.removeLast() != null)
- ;
- } catch (NoSuchElementException e) {
- }
LinkedList遍历效率分析:
- package com.sheepmu;
- import java.util.Iterator;
- import java.util.LinkedList;
- import java.util.NoSuchElementException;
- /*
- * @author SheepMu
- */
- public class LinkedListTest {
- public static void main(String[] args) {
- LinkedList<Integer> llist = new LinkedList<Integer>();
- for (int i=0; i<100000; i++)
- llist.addLast(i);
- byCommonFor(llist) ;// 通过一般for循环来遍历LinkedList
- byForEach(llist) ; // 通过for-each来遍历LinkedList
- byIterator(llist) ; // 通过Iterator来遍历LinkedList
- byPollFirst(llist) ; // 通过PollFirst()遍历LinkedList
- byPollLast(llist) ; // 通过PollLast()遍历LinkedList
- byRemoveFirst(llist) ; // 通过removeFirst()遍历LinkedList
- byRemoveLast(llist) ; // 通过removeLast()遍历LinkedList
- }
- private static void byCommonFor(LinkedList<Integer> list) {// 通过一般for循环来遍历LinkedList
- if (list == null)
- return ;
- long start = System.currentTimeMillis();
- int size = list.size();
- for (int i=0; i<size; i++) {
- list.get(i);
- }
- long end = System.currentTimeMillis();
- long total = end - start;
- System.out.println("byCommonFor------->" + total+" ms");
- }
- private static void byForEach(LinkedList<Integer> list) {// 通过for-each来遍历LinkedList
- if (list == null)
- return ;
- long start = System.currentTimeMillis();
- for (Integer integ:list)
- ;
- long end = System.currentTimeMillis();
- long total = end - start;
- System.out.println("byForEach------->" + total+" ms");
- }
- private static void byIterator(LinkedList<Integer> list) {// 通过Iterator来遍历LinkedList
- if (list == null)
- return ;
- long start = System.currentTimeMillis();
- for(Iterator iter = list.iterator(); iter.hasNext();)
- iter.next();
- long end = System.currentTimeMillis();
- long total = end - start;
- System.out.println("byIterator------->" + total+" ms");
- }
- private static void byPollFirst(LinkedList<Integer> list) {//通过PollFirst()遍历LinkedList
- if (list == null)
- return ;
- long start = System.currentTimeMillis();
- while(list.pollFirst() != null)
- ;
- long end = System.currentTimeMillis();
- long total = end - start;
- System.out.println("byPollFirst------->" + total+" ms");
- }
- private static void byPollLast(LinkedList<Integer> list) {// 通过PollLast()遍历LinkedList
- if (list == null)
- return ;
- long start = System.currentTimeMillis();
- while(list.pollLast() != null)
- ;
- long end = System.currentTimeMillis();
- long total = end - start;
- System.out.println("byPollLast------->" + total+" ms");
- }
- private static void byRemoveFirst(LinkedList<Integer> list) {// 通过removeFirst()遍历LinkedList
- if (list == null)
- return ;
- long start = System.currentTimeMillis();
- try {
- while(list.removeFirst() != null)
- ;
- } catch (NoSuchElementException e) {
- }
- long end = System.currentTimeMillis();
- long total = end - start;
- System.out.println("byRemoveFirst------->" + total+" ms");
- }
- private static void byRemoveLast(LinkedList<Integer> list) {// 通过removeLast()遍历LinkedList
- if (list == null)
- return ;
- long start = System.currentTimeMillis();
- try {
- while(list.removeLast() != null)
- ;
- } catch (NoSuchElementException e) {
- }
- long end = System.currentTimeMillis();
- long total = end - start;
- System.out.println("byRemoveLast------->" + total+" ms");
- }
- }
byCommonFor------->5342 ms
byForEach------->11 ms
byIterator------->8 ms
byPollFirst------->4 ms
byPollLast------->0 ms
byRemoveFirst------->0 ms
byRemoveLast------->0 ms
由此可见,遍历LinkedList时,使用removeFist()或removeLast()效率最高。但用它们遍历时,会删除原始数据;若单纯只读取,而不删除,LinkedList遍历时建议使用For-each或者迭代器的方式。千万不要通过随机访问去遍历LinkedList!
2.LinkedList应用举例
a.LinkedList常用方法举例
- package com.sheepmu;
- import java.util.LinkedList;
- /*
- * @author SheepMu
- */
- public class LinkedListTest {
- public static void main(String[] args) {
- commonMethods() ; // 测试LinkedList的常用方法
- likeStack();// 将LinkedList当作 LIFO(后进先出)的堆栈
- likeQueue(); // 将LinkedList当作 FIFO(先进先出)的队列
- }
- private static void commonMethods() {
- LinkedList<String> llist = new LinkedList<String>();
- llist.add("A");//添加元素
- llist.add("B");
- llist.add("C");
- llist.add("D");
- System.out.println("llist------->"+llist);
- llist.add(1, "E");// 将“E”添加到第索引为1的个位置
- System.out.println("添加E到索引为1的个位置后的llist------->"+llist);
- llist.addFirst("X");// 将“X”添加到第一个位置。 失败的话,抛出异常!
- System.out.println("在最前面添加X后的llist------->"+llist);
- System.out.println("删除第一个元素并获得并返回被删除元素----->"+llist.removeFirst()); // 将第一个元素删除。
- System.out.println("删除第一个元素后的llist------->"+llist);
- llist.offerFirst("Y");// 将“Y”添加到第一个位置。 返回true。
- System.out.println("将Y添加到第一个位置后的llist------->"+llist);
- System.out.println("删除第一个元素并获得并返回被删除元素------>"+llist.pollFirst()); // 将第一个元素删除。
- System.out.println("将第一个元素删除后的llist------->"+llist);
- llist.removeLast() ;
- System.out.println("移除最后一个元素后的llist------->"+llist);
- llist.offerLast("Z"); // 将“Z”添加到最后一个位置
- System.out.println("在最后添加Z后的llist------->"+llist);
- llist.set(2, "M");// 将第3个元素设置M。
- System.out.println("将第3个元素设置M后的llist------->"+llist);
- System.out.println("size:"+llist.size());// LinkedList大小
- llist.clear();// 清空LinkedList
- }
- private static void likeStack() { //将LinkedList作为栈使用!!!!!!!!!!!!
- LinkedList<String> stack = new LinkedList<String>();
- stack.push("A");//向栈中添加元素
- stack.push("B");
- stack.push("C");
- stack.push("D");
- System.out.println("stack--------->"+stack);
- stack.pop() ;// 删除“栈顶元素”
- System.out.println("删除栈顶后的stack--------->"+stack);
- System.out.println("栈顶元素--------->"+stack.peek()); // 取出栈顶
- }
- private static void likeQueue() {//将LinkedList作为队列使用!!!!!!!!!!!!
- LinkedList<String> queue = new LinkedList<String>();
- queue.add("A");//向队列中添加元素
- queue.add("B");
- queue.add("C");
- queue.add("D");
- System.out.println("queue--------->"+queue);
- queue.remove() ;//删除队列的第一个元素
- System.out.println("删除队列的第一个元素后queue--------->"+queue);
- System.out.println("队列第一个元素------->"+queue.element()); // 读取队列的第一个元素
- }
- }
llist------->[A, B, C, D]
添加E到索引为1的个位置后的llist------->[A, E, B, C, D]
在最前面添加X后的llist------->[X, A, E, B, C, D]
删除第一个元素并获得并返回被删除元素----->X
删除第一个元素后的llist------->[A, E, B, C, D]
将Y添加到第一个位置后的llist------->[Y, A, E, B, C, D]
删除第一个元素并获得并返回被删除元素------>Y
将第一个元素删除后的llist------->[A, E, B, C, D]
移除最后一个元素后的llist------->[A, E, B, C]
在最后添加Z后的llist------->[A, E, B, C, Z]
将第3个元素设置M后的llist------->[A, E, M, C, Z]
size:5
stack--------->[D, C, B, A]
删除栈顶后的stack--------->[C, B, A]
栈顶元素--------->C
queue--------->[A, B, C, D]
删除队列的第一个元素后queue--------->[B, C, D]
队列第一个元素------->B
Java LinkList遍历方式的更多相关文章
-
java map遍历方式及效率
本文转载自Java Map遍历方式的选择. 只给出遍历方式及结论.测试数据可以去原文看. 如果你使用HashMap 同时遍历key和value时,keySet与entrySet方法的性能差异取决于ke ...
-
Java Map遍历方式的选择
[原文] 1. 阐述 对于Java中Map的遍历方式,很多文章都推荐使用entrySet,认为其比keySet的效率高很多.理由是:entrySet方法一次拿到所有key和value的集合:而keyS ...
-
分析*(八)- List.java 各种遍历方式及遍历时移除元素的方法
注:玩的是JDK1.7版本 1:先尝栗子,再分析,代码简单,注释清晰,可自玩一下 /** * @description:测试集合遍历和移除元素的方式 * @author:godtrue * @crea ...
-
Java HashMap 遍历方式探讨
JDK8之前,可以使用keySet或者entrySet来遍历HashMap,JDK8中引入了map.foreach来进行遍历. keySet其实是遍历了2次,一次是转为Iterator对象,另一次是从 ...
-
Java Map各遍历方式的性能比较
1. 阐述 对于Java中Map的遍历方式,很多文章都推荐使用entrySet,认为其比keySet的效率高很多.理由是:entrySet方法一次拿到所有key和value的集合:而keySet拿到的 ...
-
Java 集合 ArrayList和LinkedList的几种循环遍历方式及性能对比分析 [ 转载 ]
Java 集合 ArrayList和LinkedList的几种循环遍历方式及性能对比分析 @author Trinea 原文链接:http://www.trinea.cn/android/arrayl ...
-
Java中List集合的三种遍历方式(全网最详)
List集合在Java日常开发中是必不可少的,只要懂得运用各种各样的方法就可以大大提高我们开发的效率,适当活用各种方法才会使我们开发事半功倍. 我总结了三种List集合的遍历方式,下面一一来介绍. 首 ...
-
java集合遍历的几种方式总结及比较
集合类的通用遍历方式, 用迭代器迭代: Iterator it = list.iterator(); while(it.hasNext()) { Object obj = it.next(); } ...
-
【Java】集合遍历--List和Map的多种遍历方式
1. List的两种遍历方式 package com.nova.test; import java.util.ArrayList; import java.util.Iterator; import ...
随机推荐
-
Hyper-V端口映射
有时候我们为了让局域网或外网用户直接远程访问或访问虚拟机里的服务,可以将实机端口直接映射到Hyper-V的虚拟机里面,省去很多麻烦. 下面是hyper-v共享IP端口映射一些常用命令共享IP端口映射一 ...
-
jquery 监听所有锚点链接实现平滑移动
jquery 监听所有锚点链接实现平滑移动,地址栏上不会改变链接地址 //监听所有锚点链接实现平滑移动 $('a[href*=#],area[href*=#]').click(function() { ...
-
ms sql 2005和2008收缩日志的方法
步骤1: 2005的sql 语句为:back up log 数据库名称 with no_log 目的:截断数据库日志 2008的sql 语句为:alter database 数据库名称 set rec ...
-
Poisson回归模型
Poisson回归模型也是用来分析列联表和分类数据的一种方法,它实际上也是对数线性模型的一种,不同点是对数线性模型假定频数分布为多项式分布,而泊松回归模型假定频数分布为泊松分布. 首先我们来认识一下泊 ...
-
记一次阿里云Linux服务器安装.net core sdk的问题以及解决方法
因为公司领导要求新的项目能跨平台部署,也就是说能部署到Linux服务器上,故新的项目采用了Asp.net mvc core 1.1 进行开发.开发过程一切都比较顺利,然后在之前申请试用的一台微软Azu ...
-
基于MATLAB的中值滤波均值滤波以及高斯滤波的实现
基于MATLAB的中值滤波均值滤波以及高斯滤波的实现 作者:lee神 1. 背景知识 中值滤波法是一种非线性平滑技术,它将每一像素点的灰度值设置为该点某邻域窗口内的所有像素点灰度值的中值. 中值滤 ...
-
【特性】MySQL 8 新特性
MySQL 8.0 正式版 8.0.11 已发布,官方表示 MySQL 8 要比 MySQL 5.7 快 2 倍,还带来了大量的改进和更快的性能! 注意:从 MySQL 5.7 升级到 MySQL 8 ...
-
回文树&;后缀自动机&;后缀数组
KMP,扩展KMP和Manacher就不写了,感觉没多大意思. 之前感觉后缀自动机简直可以解决一切,所以不怎么写后缀数组. 马拉车主要是通过对称中心解决问题,有的时候要通过回文串的边界解决问题 ...
-
python爬虫-图片批量下载
# 爬起摄图网的图片批量下载# coding:utf-8 import requests from bs4 import BeautifulSoup from scipy.misc import im ...
-
安卓开发笔记——ListView加载性能优化ViewHolder
在前不久做安卓项目的时候,其中有个功能是爬取某网站上的新闻信息,用ListView展示,虽然做了分页,但还是觉得达不到理想流畅效果. 上网查阅了些资料,发现一些挺不错的总结,这里记录下,便于复习. 当 ...