本文目錄一覽:
小弟跪求好的JAVA網站製作的菜鳥教程and書
哥們我這有很多網站,應該至少有一個適合你的
所屬論壇: JAVA論壇
正文內容:
java方面的:
it人資訊交流網
這個網站是我最近才發現的,雖然內容不多,但是提供的相關java工具挺齊全。還有就是裡面提供了java教學視頻錄象的免費下載,好像一兩周更換一段。個人覺得挺適合初學者的,尤其是那個classpath的設置,講的很透徹,大家有空可以看一看。
java官方站點(英文)
要想了解最新的java動態,下載最新的java相關,比如j2se、j2ee、j2se的最新jdk版本就來這裡吧。
java中文站
這個可能大家都知道,不用說了,他提供的java資源是最豐富的。註冊論壇是免費的,還送積分,用積分可以下載軟體和電子書等,如果積分用完了,就需要自己發表一些文章來賺新的積分。
中文java網站
跟上面站點類似的一個站,宗旨就是:為java愛好者服務。值得一看!
鋒網
綜合性的java網站,內含「下載中心」、「教程教學」等欄目。
java動力
網站的內容可以,但是最為出色的是它所運用的flash技術,我就不在這裡多說了,大家去看看就知道了,一個字「酷」!!!
vc方面的:
vc知識庫
這個網站就不用多說了,學習vc必去之地。網站專門提供了免費的ftp下載,好東東巨多!
vc之路
綜合軟體開發網站,以vc為主。「資源中心」有許多值得下載的東東。
visual c++/mfc開發指南
以講述windows開發為主的站點,提供了最新的源代碼,開發工具,開發資料,開發教程和對好的開發站點,開發工具,圖書做介紹,同時為從事開發的朋友提供發布自己開發的軟體,代碼和工具場所。
c維擁?
最近發現的vc好站,書籍、軟體、代碼下載一應具全!!!
遊戲開發:
風雲工作室
標點遊戲製作
未來開發者
綜合的:
中國軟體網
中國最大的開發者網路,他之所以著名就是因為他的論壇,大家有空可以去看看,能下到很多不錯的東東,另外也是交流學習的好地方。
電子書籍的:
最後公布一個巨好的,狂多的電子書下載
還有巨好的
北大青鳥設計培訓:菜鳥怎樣才能把Java開發學好?
作為一個Java菜鳥,沒有誰不想飛得更高的,但是現狀往往是Java菜鳥不怎麼能夠在短期內飛得高,要飛得高有什麼捷徑嗎?自然是有的,對於一個Java菜鳥來說,如何學Java,才能夠成為人生的贏家呢?這就是北大青鳥小編今天要跟你一起討論的問題,趕緊跟南寧北大青鳥往下看,Java菜鳥如何學Java好呢?Java菜鳥如何學Java好呢?1.很多Java菜鳥,選擇學Java的方式,就是買多本Java書籍,書是買了,看沒看,是個問題。
看書學Java,這是有用的,這也是肯定的,但是書買得多就真的能夠學好Java嗎?其實,從大部分的Java菜鳥學習中,已經看出來了,從作用和效率來講,初期看太多書學Java沒多大用處的,書的作用在於讓你查缺補漏,真正提升自己,而不是囫圇吞棗。
2.很多Java菜鳥甚至什麼是Java都不知道,然後就直接開始了Java的學習,這就是我們時常採取的獲取信息的方式,走馬觀花的學。
走馬觀花,那麼是肯定學不好Java的,這是毋庸置疑的。
作為一個Java菜鳥,學習Java必須有一個系統的學習方案,系統的學習教程,這樣才能夠確保自己學到的Java效果最佳。
3.Java菜鳥如何學Java好呢?當下對於一個毫無編程經驗的Java菜鳥來說,學Java最佳的方式,就是找一個靠譜的Java培訓機構,因為自學Java,遭遇重重困難,都得自己一個人默默的解決,關鍵是很多時候都是無能為力,不知道該從何解決。
而在Java培訓機構,有著專業的老師永遠是你堅強的後盾。
ArrayDeque
寫cs61b題目時驚嘆為什麼會有這種東西,於是搜索了一番,發現這容器還是很有意思的,於是搬運了一下。
參考: ArrayDeque – (jianshu.com)
Java ArrayDeque – Java教程 – 菜鳥教程 (cainiaojc.com)
在ArrayDeque類實現這兩個介面:Java Queue和Java Deque
使用了數組來存儲數據,同時用兩個int值 head 和 tail 來表示頭部和尾部。不過需要注意的是 tail 並不是尾部元素的索引,而是尾部元素的 下一位 ,即下一個將要被加入的元素的索引。
ArrayDeque 有三個構造函數來初始化,除了無參的構造函數使用了默認容量,其它兩個構造函數會通過 allocateElements 函數來計算初始容量
數組的大小很特殊,大小必為2的n次方(2^n)。下面我們看看 allocateElements 方法
(1)對於一個小於2^30的值,經過五次右移和位或操作後,可以得到一個 2^k – 1 的值。最後再將這個值 +1 ,得到 2^k 。通過這個方法,可以將一個任意的初始值轉化為2^n的值.
(2)不過有一點不足在於,如果本身傳進來的值就是 2^n 的值,那麼經過轉化會變成 2^(n+1) ,所以我們在不用刻意去傳入 2^n 的值。
(3)如果傳入的值大於等於 2^30 ,那麼經過轉化會變成負值,即 0,此時會把初始值設置為 2^30 ,即最大的容量只有 2^30
在ArrayDeque中,數組是作為環形來使用的,正常情況下在末尾添加元素後,tail=tail+1是要判斷是否越界,如果越界,會變為從索引0開始。參考如下圖片,當H添加到索引7後,tail值會+1,此時tail=8,但是越界了,所以應該將tail設置為0。
我們看看 tail = (tail + 1) (elements.length – 1) 的正確性:
所以當 tail+1 = length – 1 ,此時數組並沒有越界, (tail + 1) (elements.length – 1) 後得到的還是 tail+1 。如果 tail + 1 = length ,此時數組越界了, (tail + 1) (elements.length – 1) 後得到0。
所以通過 (tail + 1) (elements.length – 1) 可以跳過條件判斷在環形數組中獲取正確的索引值,然後再判斷新的 tail 是否等於 head ,如果結果為 true ,那麼數組已經滿了,需要擴容,即 doubleCapacity() 。
原理和addLast相同
無論是從頭部還是從尾部添加元素,都會判斷 tail==head ,如果兩個索引相遇,說明數組空間已滿,需要擴容操作.
ArrayDeque支持從頭尾兩端移除元素
在上文中,我們講了怎麼去實現一個ArrayDeque,但Java標準庫中已經為我們準備好了,我們只需按規則使用就行
add() – 將指定的元素插入ArrayDeque雙端隊列的 末尾
addFirst() -在ArrayDeque雙端隊列的 開頭 ,插入指定的元素
addLast() – 在ArrayDeque雙端隊列的 末尾 插入指定的內容(等效於 add() )
注意:如果ArrayDeque雙端隊列已滿,則所有這些方法 add() , addFirst() 和 addLast() 都會引發IllegalStateException
offer() – 將指定的元素插入ArrayDeque雙端隊列的 末尾
offerFirst() – 在ArrayDeque雙端隊列的 開始處 插入指定的元素
offerLast() – 將指定的元素插入ArrayDeque雙端隊列的 末尾
注意: offer(),offerFirst()並offerLast()返回true是否成功插入元素;否則,返回。如果ArrayDeque雙端隊列已滿,則這些方法返回false。
getFirst() – 返回ArrayDeque雙端隊列的 第一個元素
getLast() – 返回ArrayDeque雙端隊列的 最後一個元素
註:如果ArrayDeque雙端隊列為空,getFirst()和getLast()拋出NoSuchElementException。
peek() – 返回ArrayDeque雙端隊列的 第一個 元素
peekFirst() – 返回ArrayDeque雙端隊列的 第一個 元素(等效於 peek() )
peekLast() – 返回ArrayDeque雙端隊列的 最後一個 元素
註:如果ArrayDeque雙端隊列為空,peek(),peekFirst()和getLast()拋出 NoSuchElementException
remove() – 返回並從ArrayDeque雙端隊列的 第一個 元素中刪除一個元素
remove(element) – 返回並從ArrayDeque雙端隊列的 頭部 刪除指定的元素
removeFirst() – 返回並從ArrayDeque雙端隊列中刪除 第一個 元素(等效於remove())
removeLast() – 返回並從ArrayDeque雙端隊列中刪除 最後一個元素
注意:如果數組雙端隊列為空,則remove(),removeFirst()和removeLast()方法將引發異常。 另外,如果找不到元素,則remove(element)會引發異常。
poll() – 返回並刪除ArrayDeque雙端隊列的 第一個 元素
pollFirst() – 返回並刪除ArrayDeque雙端隊列的 第一個 元素(等效於poll())
pollLast() – 返回並刪除ArrayDeque雙端隊列的 最後一個 元素
注意:如果ArrayDeque雙端隊列為空,則如果找不到該元素,則poll(),pollFirst()和pollLast()返回null。
刪除所有元素
iterator() – 返回可用於遍歷ArrayDeque雙端隊列的 迭代器
descendingIterator() -返回一個迭代器,該迭代器可用於以 相反順序 遍歷ArrayDeque雙端隊列
註:為了使用這些方法,我們必須導入java.util.Iterator包。
使用迭代器的方法如下
element() -從ArrayDeque雙端隊列的頭部返回一個元素。
contains(element) -在ArrayDeque雙端隊列中搜索指定的元素。如果找到該元素,則返回true,否則返回false。
size() -返回ArrayDeque雙端隊列的長度。
toArray() -將ArrayDeque雙端隊列轉換為數組並返回。
clone() -創建ArrayDeque雙端隊列的副本並返回它。
push() – 在堆棧頂部添加一個元素
peek() – 從堆棧頂部返回一個元素
pop() – 返回並從堆棧頂部刪除元素
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/232145.html