分区
个性化频道

使用Java实现各种数据结构(视频教学)

Java中有几种常用的数据结构,主要分为Collection和map两个主要接口(接口只提供方法,并不提供实现),而程序中最终使用的数据结构是继承自这些接口的数据结构类。

一、几个常用类的区别
1.ArrayList: 元素单个,效率高,多用于查询
2.Vector: 元素单个,线程安全,多用于查询
3.LinkedList:元素单个,多用于插入和删除
4.HashMap: 元素成对,元素可为空
5.HashTable: 元素成对,线程安全,元素不可为空
二、Vector、ArrayList和LinkedList
大多数情况下,从性能上来说ArrayList最好,但是当集合内的元素需要频繁插入、删除时LinkedList会有比较好的表现,但是它们三个性能都比不上数组,另外Vector是线程同步的。所以:
如果能用数组的时候(元素类型固定,数组长度固定),请尽量使用数组来代替List;
如果没有频繁的删除插入操作,又不用考虑多线程问题,优先选择ArrayList;
如果在多线程条件下使用,可以考虑Vector;
如果需要频繁地删除插入,LinkedList就有了用武之地;
如果你什么都不知道,用ArrayList没错。
三、Collections和Arrays
在Java集合类框架里有两个类叫做Collections(注意,不是Collection!)和Arrays,这是JCF里面功能强大的工具,但初学者往往会忽视。按JCF文档的说法,这两个类提供了封装器实现(Wrapper Implementations)、数据结构算法和数组相关的应用。
想必大家不会忘记上面谈到的“折半查找”、“排序”等经典算法吧,Collections类提供了丰富的静态方法帮助我们轻松完成这些在数据结构课上烦人的工作:
binarySearch:折半查找。
sort:排序,这里是一种类似于快速排序的方法,效率仍然是O(n * log n),但却是一种稳定的排序方法。
reverse:将线性表进行逆序操作,这个可是从前数据结构的经典考题哦!
rotate:以某个元素为轴心将线性表“旋转”。
swap:交换一个线性表中两个元素的位置。
……
Collections还有一个重要功能就是“封装器”(Wrapper),它提供了一些方法可以把一个集合转换成一个特殊的集合,如下:
unmodifiableXXX:转换成只读集合,这里XXX代表六种基本集合接口:Collection、List、Map、Set、SortedMap和SortedSet。如果你对只读集合进行插入删除操作,将会抛出UnsupportedOperationException异常。
synchronizedXXX:转换成同步集合。
singleton:创建一个仅有一个元素的集合,这里singleton生成的是单元素Set,
singletonList和singletonMap分别生成单元素的List和Map。
空集:由Collections的静态属性EMPTY_SET、EMPTY_LIST和EMPTY_MAP表示。

预览图(不是全部,仅作示例):

下载权限

查看
  • 免费下载
    评论并刷新后下载
    登录后下载

查看演示

  • {{attr.name}}:
您当前的等级为
登录后免费下载登录 小黑屋反思中,不准下载! 评论后刷新页面下载评论 本作为UP主、推广大使和VIP专享内容 升级会员

您今天的下载次数(次)用完了,请明天再来 本作为UP主、推广大使和VIP专享内容 升级会员

支付以后下载立即支付 本作为UP主、推广大使和VIP专享内容 升级会员

您已获得下载权限 您已获得下载权限,您可以每天下载资源次,今日剩余
使用手机APP搜索
即可使用极速下载功能
该游戏只支持安卓手机
使用手机浏览器-首页右上角-扫一扫保存到手机
还没有APP/不会使用?

国际网盘分流下载

猜您喜欢

11 条回复 A文章作者 M管理员
  1. 天上的光
    天上的光

    把萌站当CSDN了?

  2. iafy201834
    iafy201834

    链接已炸,求补

  3. 天天ll
    天天ll

    求大佬补一下 [压力]

  4. huacishu
    huacishu

    大佬,能补下链接吗

  5. labrbre
    labrbre

    C的是c++吗,那我还是看java

  6. dashabi233
    dashabi233

    可惜没有c的,最近正在学

    • Yinzi_Mike
      Yinzi_MikeA@dashabi233

      有的,我发了 [van♂样的肯定]

    • Yinzi_Mike
      Yinzi_MikeA@dashabi233

      注意不是这篇,翻我的空间吧 [van♂样的肯定]

    • BTSD
      BTSD@Yinzi_MikeA

      正好我在学信息管理都可以用 [van♂样的肯定]

    • dashabi233
      dashabi233@Yinzi_MikeA

      看到了看到了,给你个赞 [van♂样的肯定]

    • Yinzi_Mike
      Yinzi_MikeA@dashabi233

      [van♂样的肯定]

打开客户端
取消
下载方式 X