国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

Java 持有對象(11)

summerpxy / 709人閱讀

摘要:如果一個程序只包含固定數(shù)量且其生命周期都是已知的對象,那么這是一個非常簡單的程序。

如果一個程序只包含固定數(shù)量且其生命周期都是已知的對象,那么這是一個非常簡單的程序。

1.泛型和類型安全的容器

通過使用泛型,可以在編譯期防止將錯誤類型的對象放置到容器中.

2.基本概念

Java容器類庫的用途是"保存對象",并將其劃分為兩個不同的概念:CollectionMap.

Collection:一個獨立元素的序列,這些元素都服從一條或多條規(guī)則.

Map:一組成對的"鍵值對"對象,允許你使用鍵來查找值.

3.添加一組元素

在java.util包中的Arrays和Collections類中都有很多實用方法,可以在一個Collection中添加一組元素.

4.容器的打印

默認的打印行為(使用容器提供的toString()方法)即可生成可讀性很好的結(jié)果.

5.List

List承諾可以將元素維護在特定的序列中.List接口在Collection的基礎(chǔ)上添加了大量的方法,使得可以在List的中間插入和移除元素.

有兩種類型的List:ArrayList,LinkedList.

ArrayList:擅長于隨機訪問元素,但是在List的中間插入和移除元素時比較慢.

LinkedList:在隨機訪問方面相對比較慢,但是它的特性集較ArrayList更大.

6.迭代器

任何容器類,都必須有某種方式可以插入元素并將它們再次取回.

迭代器是一個對象,它的工作是遍歷并選擇序列中的對象,而客戶端程序員不必知道或關(guān)心該序列底層的結(jié)構(gòu).

迭代器通常被稱為輕量級對象:創(chuàng)建它的代價小.

ListIterator是一個更加強大的Iterator的子類型,它只能用于各種List的訪問.

7.LinkedList

LinkedList也像ArrayList一樣實現(xiàn)了基本的List接口,但是它執(zhí)行某些操作(在List的中間插入和移除)時比ArrayList更高效,但在隨機訪問操作方面卻要遜色一些.

LinkedList還添加了可以使其用作棧,隊列或雙端隊列的方法.

8.棧

"棧"通常是指"后進先出"(LIFO)的容器.有時棧也被稱為疊加棧.

LinkedList具有能夠直接實現(xiàn)棧的所有功能的方法,因此可以直接將LinkedList作為棧使用.

9.Set

Set不保存重復(fù)的元素.

Set具有與Collection完全一樣的接口,因此沒有任何額外的功能.

實際上Set就是Collection,只是行為不同.

Set是基于對象的值來確定歸屬性的(Set中最常被使用的是測試歸屬性:contains()).

10.Map

將對象映射到其他對象.

11.Queue

Queue是一個典型的先進先出(FIFO)的容器.

隊列在并發(fā)編程中特別重要,因為它們可以安全地將對象從一個任務(wù)傳輸?shù)搅硪粋€任務(wù).

LinkedList提供了方法以支持隊列的行為,并且它實現(xiàn)了Queue接口,因此LinkedList可以用作Queue的一種實現(xiàn).

PriorityQueue:優(yōu)先級隊列聲明下一個彈出元素就是最需要的元素(具有最高的優(yōu)先級).

12.Collection和Iterator

Collection是描述所有序列容器的共性的跟接口,它可能會被認為是一個"附屬接口",即因為要表示其他若干個接口的共性而出現(xiàn)的接口.

容器之間的共性是通過迭代器達成的,而不是Collection來表示.但是,這個兩個方法綁定到了一起,因為實現(xiàn)Collection就意味著需要提供iterator()方法.

13.Foreach與迭代器

Java SE5引入了新的被稱為Iterable的接口,該接口包含一個能夠產(chǎn)生Iterator的iterator()方法,并且Iterable接口被foreach用來在序列中移動.

在Java SE5中,大量的類都是Iterable類型,主要包括所有的Collection類(但是不包括各種Map).

適配器方法的慣用法.

END

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/71666.html

相關(guān)文章

  • Java編程思想》筆記11.持有對象

    摘要:迭代器通常被成為輕量級對象創(chuàng)建它的代價很小。與迭代器可以用于數(shù)組和所有對象,之所以能夠工作,是因為繼承了接口。 點擊進入我的博客 我覺得本章名字改成容器似乎更好理解,持有對象讓人感到一頭霧水我們需要在任意時刻和任意位置創(chuàng)建任意數(shù)量的對象,所以依靠創(chuàng)建命名的引用來持有對象已經(jīng)滿足不了需求。Java可以用數(shù)組和其他容器類來(List、Set、Queue、Map)來解決這個問題,不同的容器...

    newtrek 評論0 收藏0
  • (Thinking in Java)第11持有對象

    摘要:迭代器解決了這個問題。刪除后于是我們可以寫一個方法,接受一個類型,然后讓他調(diào)用方法,這就不需要考慮這個是個還是了,也就是說,可以將遍歷容器的操作與序列底層的結(jié)構(gòu)分離,迭代器統(tǒng)一了對容器類的訪問方式。十二和兩種遍歷的方法,與迭代器方法。 一、泛型和類型安全的容器 package tij.hoding; import java.util.ArrayList; public class ...

    v1 評論0 收藏0
  • Java編程思想》-- 持有對象 -- 添加一組元素

    摘要:方法接受一個對象,以及一個數(shù)組或是一個用逗號分隔的列表,并將元素添加到中。工作的很好,因為他從第一個參數(shù)中了解到了目標(biāo)類型是什么。 ArrayList.asList() 接受一個數(shù)組或是用逗號分隔的元素列表,也可以用可變參數(shù),然后將其轉(zhuǎn)為一個List對象。 Collections.addAll()方法接受一個Collection對象,以及一個數(shù)組或是一個用逗號分隔的列表,并將元素添加...

    tomlingtm 評論0 收藏0
  • 第十一章 持有對象

    摘要:允許從任一方向來遍歷對象,并在遍歷迭代過程中進行修改該對象,還能獲得迭代器的當(dāng)前位置。這個構(gòu)造函數(shù)是將返回了一個對象給,這也是的存儲實現(xiàn)原理。 一、容器產(chǎn)生的原因   1.數(shù)組的缺點:大小一旦給定就無法更改,除非復(fù)制到一個新的數(shù)組中,開銷大;而容器類都可以自動地調(diào)整自己的尺寸。  2.容器功能的多樣性:容器可以實現(xiàn)各種不同要求,如按不同依據(jù)將元素進行排序或者保證容器內(nèi)無重復(fù)元素等等。關(guān)...

    archieyang 評論0 收藏0
  • 并發(fā)編程之死鎖解析

    摘要:如何檢測死鎖由于死鎖極難通過人工的方式查出來,因此提供了命令來檢測某個進程中心線程的情況,并排查有沒有死鎖。線程持有的鎖,等待的鎖。避免出現(xiàn)死鎖,如果出現(xiàn)了死鎖,則可以使用命令查看線程是否有死鎖。 showImg(https://segmentfault.com/img/remote/1460000014936757); 前言 在 Java 的并發(fā)編程中,有一個問題需要特別注意,那就是...

    yy736044583 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<