`
逆风的香1314
  • 浏览: 1440147 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

老紫竹JAVA提高教程(6)-认识List列表

阅读更多
原文地址:http://www.java2000.net/p11848
 
列表是很常用的数据结构,感觉比Map和Set用的频率要高一些吧,因为我经常用其返回数据库的操作结果集

  1. package collection.lession6;
  2. import java.util.ArrayList;
  3. import java.util.Iterator;
  4. import java.util.LinkedList;
  5. import java.util.List;
  6. import java.util.ListIterator;
  7. import java.util.Stack;
  8. import java.util.Vector;
  9. /**
  10.  * 老紫竹JAVA提高教程(6)-认识List列表<br>
  11.  * List可以精确控制在集合里面的先后顺序。<br>
  12.  * 可以直接通过数据的位置访问数据。<br>
  13.  * 一般允许重复数据<br>
  14.  * 一般允许null,且允许多个null
  15.  * 
  16.  * @author 老紫竹 JAVA世纪网(java2000.net)
  17.  * 
  18.  */
  19. public class Lession6 {
  20.   public static void main(String[] args) {
  21.     // 下面是List里面常用的实现类
  22.     // 大小可变列表的实现,允许任何数据加入
  23.     ArrayList arrayList = new ArrayList();
  24.     // 同样是大小可变列表的实现.
  25.     // 与ArrayList的最大区别就是这个类的方法是同步(synchronized)的
  26.     // 详细的区别,请参考
  27.     // 看源代码理解ArrayList和Vector 的真正区别
  28.     // http://www.java2000.net/p9750
  29.     Vector vector = new Vector();
  30.     // 实现了双向队列的控制,包括头尾的操作
  31.     // 可用于堆栈和FIFO操作等
  32.     LinkedList linkedList = new LinkedList();
  33.     // 集成自 Vector
  34.     // 提供了LIFO的堆栈操作方式
  35.     Stack stack = new Stack();
  36.     // -----------------
  37.     // 下面以ArrayList作为例子,看看列表的各个方法
  38.     List list = new ArrayList();
  39.     // 构建第二个列表
  40.     List list2 = new ArrayList();
  41.     // 向列表的尾部添加指定的数据
  42.     list.add(123);
  43.     // 在列表的指定位置插入指定数据
  44.     // 我们在最前面插入数据
  45.     // 列表的位置索引从0开始
  46.     list.add(0456);
  47.     // 将list2里面的数据,全部放到list1的尾部去
  48.     // 注意此处可以是任何集合类,不限于列表
  49.     list.addAll(list2);
  50.     // 将list2里面的数据,全部放到list1指定位置的后面
  51.     // 等于插入一段数据
  52.     list.addAll(2, list2);
  53.     // 清空列表,删除里面所有的数据
  54.     list.clear();
  55.     // 判断列表里是否包含某个数据
  56.     boolean found = list.contains(123);
  57.     // 判断列表是否包含了另一个集合的所有数据
  58.     // 注意此处可以是任何集合类,不限于列表
  59.     boolean ok = list.containsAll(list2);
  60.     // 获得指定位置的数据
  61.     // 如果位置超过了列表的范围 0 到 list.size()-1
  62.     // 则抛出异常:IndexOutOfBoundsException
  63.     Object obj = list.get(3);
  64.     // 得到数据在列表中的位置
  65.     // 如果没找到,返回-1
  66.     // 位置索引从0开始
  67.     int index = list.indexOf(456);
  68.     // 判断列表是不是空的
  69.     boolean empty = list.isEmpty();
  70.     // 列表的迭代器操作
  71.     // 顺序严格按照列表的保存的顺序
  72.     Iterator it = list.iterator();
  73.     // 得到数据在列表最后一次出现的位置
  74.     // 适合于有重复数据的列表
  75.     index = list.lastIndexOf(456);
  76.     // 列表的另一个迭代器
  77.     ListIterator listIT = list.listIterator();
  78.     // 列表的另一个迭代器,可以指定起始位置
  79.     ListIterator listIT2 = list.listIterator(3);
  80.     // 删除某个位置的数据
  81.     list.remove(3);
  82.     // 删除指定对象的第一个出现的位置
  83.     // 注意,如果是整数,要区分其与remove(int)的区别
  84.     // 建议用 remove(new Integer(123)); 来删除数据对象
  85.     list.remove(new Integer(123));
  86.     // 删除列表里在另一个集合里存在的数据
  87.     list.removeAll(list2);
  88.     // 只保留在另一个集合里存在的数据,等于交集
  89.     list.retainAll(list2);
  90.     // 替换指定位置的数据
  91.     list.set(3999);
  92.     // 列表数据的数量
  93.     int size = list.size();
  94.     // 得到一个子数组
  95.     List subList = list.subList(210);
  96.     // 将集合转化为数组
  97.     Object[] objs = list.toArray();
  98.     // 将集合转化为指定格式的数组
  99.     // 比如集合里保存的都是String
  100.     String[] objs2 = (String[]) list.toArray(new String[0]);
  101.   }
  102. }

总结:
    实际上我们最常用的还是 ArrayList, Vector因为是同步方法,只有在多线程,以及全局的数据时,我才考虑用。

分享到:
评论

相关推荐

    跟老紫竹学Java-计数器项目源代码

    在本项目"跟老紫竹学Java-计数器项目源代码"中,我们主要学习如何使用不同的技术来实现一个简单的计数器功能,用于记录页面的访问次数。计数器是一个常见的应用场景,它能够帮助我们了解网站或应用的受欢迎程度。...

    老紫竹信息采集系统0.1版

    在这个项目中,Spring被用来实现动态配置,这意味着用户可以根据需求灵活地设置和更改要采集的网站列表,无需修改源代码,只需通过配置文件即可完成,大大提高了系统的可扩展性和维护性。 其次,Lucene是Apache软件...

    老紫竹网页采集系统,令你一看就上手的搜索引擎

    6. **多线程/异步处理**:理解并发编程的概念,使用Python的线程或多进程库(如threading、multiprocessing)提高爬虫的速度。 7. **搜索引擎原理**:了解搜索引擎的基本组件,包括爬虫、索引、查询解析和排序算法...

    Java5、6、7_API_帮助文档.rar

    Java 5、6、7 API 帮助文档是Java开发者的重要参考资料,涵盖了这三个关键版本的Java开发工具集(JDK)的详细功能和接口。这些API文档以CHM(Compiled Help Manual)格式提供,是一种常见的Windows平台上的帮助文件...

    loadunner进行B/S测试的培训PPT下载-老紫竹

    【LoadRunner进行B/S测试的培训PPT下载-老紫竹】 LoadRunner是一款强大的性能测试工具,主要用于评估和优化应用程序的性能。在这个培训文档中,我们主要关注的是如何使用LoadRunner进行基于B/S(Browser/Server)...

    信息采集系统(老紫竹搜索引擎0.4 测试版 包括了部分B/S程序 )

    1 完全基于人工收录,每个被收录的帖子都是我们认为不错的。 2 任何人都可以加入,别人也可以分享到你加入的内容 3 收录的内容,不是简单的抓取,而是只收录里面最有用的部分,比如主题,内容...(版权归老紫竹所有)

    老紫竹网页采集系统

    老紫竹网页采集系统=================安装配置-------1 程序我就不说了2 配置文件 applicationContext.xml 里面有详细的注释3 已经包含了CSDN论坛、博客园、新浪博客、百度Hi的解析参数需要的类库---------1 Spring ...

    紫竹本地影音文件速查器V1.0绿色免费版

    紫竹本地影音文件速查器是款针紫竹影音打造的本地音频文件查看工具。用户可以通过这款软件快速找到想要的影音文件,欢迎下载 【软件特色】  1.软件功能简单,但是非常的使用  2.省去了复杂的安装过程,解压即用...

    紫竹手机下载系统(含MP3切割组合功能)

    紫竹手机下载系统的出现,迎合了这一需求,特别是其独具特色的MP3切割组合功能,为用户提供了更为个性化和创意性的音频处理方案。本文将对紫竹手机下载系统进行详细解析,探讨其核心功能以及使用方法,旨在让更多的...

    java解析pdf

    6. **PDF解析示例** 在提供的"PDFParserDemo"中,可能包含了一个简单的PDF解析示例,例如读取并打印PDF的文本内容: ```java public class PDFParserDemo { public static void main(String[] args) throws ...

    普陀山紫竹林导游词介绍5篇精选.doc

    普陀山紫竹林导游词介绍5篇精选.doc

    NucleoF411RET6.7z

    NucleoF411RET6的TFTLCD屏和SD卡驱动 if(f_mount(&my_fs,"0:",1) == FR_OK) { printf("File mount OK!\r\n"); file_result=f_open(&my_file,"MyData.txt",FA_OPEN_EXISTING | FA_READ); if(file_result=...

    秉承初心,2019“紫竹青春健康校园行”再启征程

    根据给定文件信息,“紫竹青春健康校园行”是一个由华润紫竹药业发起并主办的公益项目,旨在向青年学生普及性教育知识,提高他们对性健康的正确认识。该项目的活动自2017年下半年开始,至2019年仍在继续,覆盖范围...

    Java Test Util

    在IT行业中,Java Test Util是一个重要的工具集合,它专门针对Java开发者设计,旨在提供一系列便捷的测试工具,帮助他们在开发过程中高效地进行单元测试、集成测试等。这些工具以其合理的价格(在这里指的是“一积分...

    紫竹国际教育园区.docx

    紫竹国际教育园区是中国上海闵行区的一个重要教育与科研基地,旨在打造世界级的高等教育集聚区和产学研深度融合示范区。该园区由闵行区人民政府与紫竹国家高新技术产业开发区共同建立,目的是结合创新型城市建设和...

    紫竹慧:2019年年度报告.PDF

    在2019年度中,紫竹慧以其在建设服务行业多年积累的专业能力,成功参与并完成了多个对地区乃至国家有着重要战略意义的大型建设项目。本报告将详细阐述紫竹慧在过去一年取得的业务成就及在重大工程项目中的贡献。 ...

    听 紫竹调小学音乐沪音五年级下册PPT学习教案.pptx

    这堂音乐课的设计充分考虑了小学生的学习特点,以生动活泼的方式教授音乐知识,旨在提高学生的音乐素养,同时培养他们的团队协作能力和艺术表现力。通过这样的教学实践,学生不仅能学习到音乐基础知识,还能感受到...

Global site tag (gtag.js) - Google Analytics