一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|

服務(wù)器之家 - 編程語言 - JAVA教程 - Java接口RandomAccess全面了解

Java接口RandomAccess全面了解

2020-06-12 14:54jingxian JAVA教程

下面小編就為大家?guī)硪黄狫ava接口RandomAccess全面了解。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

Java接口RandomAccess全面了解

在jdk文檔中對RandomAccess接口的定義如下:  public interface RandomAccess

下面是jdk的注解翻譯

List 實(shí)現(xiàn)所使用的標(biāo)記接口,用來表明其支持快速(通常是固定時間)隨機(jī)訪問。此接口的主要目的是允許一般的算法更改其行為,從而在將其應(yīng)用到隨機(jī)或連續(xù)訪問列表時能提供良好的性能。

將操作隨機(jī)訪問列表的最佳算法(如 ArrayList )應(yīng)用到連續(xù)訪問列表(如 LinkedList )時,可產(chǎn)生二次項(xiàng)的行為。如果將某個算法應(yīng)用到連續(xù)訪問列表,那么在應(yīng)用可能提供較差性能的算法前,鼓勵使用一般的列表算法檢查給定列表是否為此接口的一個 instanceof ,如果需要保證可接受的性能,還可以更改其行為。

現(xiàn)在已經(jīng)認(rèn)識到,隨機(jī)和連續(xù)訪問之間的區(qū)別通常是模糊的。例如,如果列表很大時,某些 List 實(shí)現(xiàn)提供漸進(jìn)的線性訪問時間,但實(shí)際上是固定的訪問時間。這樣的 List 實(shí)現(xiàn)通常應(yīng)該實(shí)現(xiàn)此接口。

強(qiáng)調(diào):JDK中推薦的是對List集合盡量要實(shí)現(xiàn)RandomAccess接口

如果集合類是RandomAccess的實(shí)現(xiàn),則盡量用for(int i = 0; i < size; i++) 來遍歷而不要用Iterator迭代器來遍歷。

反過來,如果List是Sequence List,則最好用迭代器來進(jìn)行迭代。

JDK中說的很清楚,在對List特別是Huge size的List的遍歷算法中,要盡量來判斷是屬于RandomAccess(如ArrayList)還是Sequence List (如LinkedList),因?yàn)檫m合RandomAccess List的遍歷算法,用在Sequence List上就差別很大,常用的作法就是:

要作一個判斷:

?
1
2
3
4
5
6
7
if (list instance of RandomAccess) {
   for(int m = 0; m < list.size(); m++){}
 }else{
   Iterator iter = list.iterator();
   while(iter.hasNext()){}
 
 }

測試:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
public class TestRandomAccess {
  @Test
  public void testTraverse() {
    ArrayList<Integer> arraylist = new ArrayList<Integer>();
    LinkedList<Integer> linkedList = new LinkedList<Integer>();
    initList(arraylist, 1000);
    initList(linkedList, 1000);
 
    System.out.println("ArrayList實(shí)現(xiàn)了RandomAccess接口");
    implRandomAccessTraverse(arraylist); //花了10ms時間
    System.out.println("LinkedList未實(shí)現(xiàn)了RandomAccess接口");
    implRandomAccessTraverse(linkedList); //花了434ms時間
 
 
    System.out.println("\nArrayList實(shí)現(xiàn)了RandomAccess接口");
    noImplRandomAccessTraverse(arraylist); //花了39ms時間
    System.out.println("LinkedList未實(shí)現(xiàn)了RandomAccess接口");
    noImplRandomAccessTraverse(linkedList); //花了27ms時間
  }
 
  private long startTime = 0;
  private long endTime = 0;
  // 初始化列表
  public void initList(List<Integer> list, int n) {
    for (int i = 0; i < n; i++) {
      list.add(i);
    }
  }
 
  //有實(shí)現(xiàn)RandomAccess接口的遍歷全部數(shù)據(jù),
  public void implRandomAccessTraverse(List list) {
    startTime = System.currentTimeMillis();
    for (int count = 0; count <= 1000; count++) {
      for (int i = 0; i < list.size(); i++) {
        list.get(i);
      }
    }
    endTime = System.currentTimeMillis();
    System.out.println("使用loop迭代一共花了" + (endTime - startTime) + "ms時間");
  }
 
  //沒有實(shí)現(xiàn)RandomAccess接口的遍歷全部數(shù)據(jù)
  public void noImplRandomAccessTraverse(List list) {
      startTime = System.currentTimeMillis();
      for (int count = 0; count <= 1000; count++) {
        for (Iterator itr = list.iterator(); itr.hasNext();) {
          itr.next();
        }
      }
      endTime = System.currentTimeMillis();
    System.out.println("使用Iterator迭代一共花了" + (endTime - startTime) + "ms時間");
  }
 
}

以上這篇Java接口RandomAccess全面了解就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持服務(wù)器之家。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国内精品久久久久影院男同志 | 亚洲v日韩v欧美在线观看 | 午夜福利电影网站鲁片大全 | 免费叼嘿视频 | 欧美在线播放一区二区 | 日韩亚洲欧美一区二区三区 | cao逼视频| 性欧美高清强烈性视频 | www.色婷婷.com | 韩国禁片在线观看久 | 免费的强动漫人物 | 精精国产www视频在线观看免费 | 男女车车好快的车车免费网站 | 欧美国产合集在线视频 | 日本成人黄色网址 | 冰山美人调教耻辱h | 国产麻豆91欧美一区二区 | 好湿好紧太硬了我太爽了h 好湿好滑好硬好爽好深视频 | 91在线视频国产 | 大乳女子一级毛片 | xxxx泡妞中国| 男人肌肌捅女人 | 亚洲瑟瑟网 | 国产日本韩国不卡在线视频 | 视频在线视频免费观看 | 午夜久久免影院欧洲 | 欧美成人免费观看国产 | 18韩国美女vip视频7 | 欧美一区二区三区在线观看免费 | 99精品视频免费 | 亚洲国产日韩欧美在线vip1区 | 欧美日韩免费一区二区在线观看 | 色呦呦入口 | 亚洲国产成人久久99精品 | 国产精品99在线观看 | 天堂在线免费观看 | 国产人成激情视频在线观看 | 欧美成人免费观看久久 | x8x8在线观看免费 | 福利片中文 | 精品视频一区二区三区免费 |