java菜鳥教程,java菜鳥教程視頻

本文目錄一覽:

小弟跪求好的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-hk/n/232145.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-11 12:50
下一篇 2024-12-11 12:50

相關推薦

  • java client.getacsresponse 編譯報錯解決方法

    java client.getacsresponse 編譯報錯是Java編程過程中常見的錯誤,常見的原因是代碼的語法錯誤、類庫依賴問題和編譯環境的配置問題。下面將從多個方面進行分析…

    編程 2025-04-29
  • Java JsonPath 效率優化指南

    本篇文章將深入探討Java JsonPath的效率問題,並提供一些優化方案。 一、JsonPath 簡介 JsonPath是一個可用於從JSON數據中獲取信息的庫。它提供了一種DS…

    編程 2025-04-29
  • Java騰訊雲音視頻對接

    本文旨在從多個方面詳細闡述Java騰訊雲音視頻對接,提供完整的代碼示例。 一、騰訊雲音視頻介紹 騰訊雲音視頻服務(Cloud Tencent Real-Time Communica…

    編程 2025-04-29
  • Java Bean加載過程

    Java Bean加載過程涉及到類加載器、反射機制和Java虛擬機的執行過程。在本文中,將從這三個方面詳細闡述Java Bean加載的過程。 一、類加載器 類加載器是Java虛擬機…

    編程 2025-04-29
  • Java Milvus SearchParam withoutFields用法介紹

    本文將詳細介紹Java Milvus SearchParam withoutFields的相關知識和用法。 一、什麼是Java Milvus SearchParam without…

    編程 2025-04-29
  • MQTT使用教程

    MQTT是一種輕量級的消息傳輸協議,適用於物聯網領域中的設備與雲端、設備與設備之間的數據傳輸。本文將介紹使用MQTT實現設備與雲端數據傳輸的方法和注意事項。 一、準備工作 在使用M…

    編程 2025-04-29
  • Python3.6.5下載安裝教程

    Python是一種面向對象、解釋型計算機程序語言。它是一門動態語言,因為它不會對程序員提前聲明變量類型,而是在變量第一次賦值時自動識別該變量的類型。 Python3.6.5是Pyt…

    編程 2025-04-29
  • Deepin系統分區設置教程

    本教程將會詳細介紹Deepin系統如何進行分區設置,分享多種方式讓您了解如何規劃您的硬盤。 一、分區的基本知識 在進行Deepin系統分區設置之前,我們需要了解一些基本分區概念。 …

    編程 2025-04-29
  • Java 8中某一周的周一

    Java 8是Java語言中的一個版本,於2014年3月18日發佈。本文將從多個方面對Java 8中某一周的周一進行詳細的闡述。 一、數組處理 Java 8新特性之一是Stream…

    編程 2025-04-29
  • Java判斷字符串是否存在多個

    本文將從以下幾個方面詳細闡述如何使用Java判斷一個字符串中是否存在多個指定字符: 一、字符串遍歷 字符串是Java編程中非常重要的一種數據類型。要判斷字符串中是否存在多個指定字符…

    編程 2025-04-29

發表回復

登錄後才能評論