摘要:有兩個重要的子類異常和錯誤,二者都是異常處理的重要子類,各自都包含大量子類。錯誤是程序無法處理的錯誤,表示運行應(yīng)用程序中較嚴(yán)重問題。異常由虛擬機拋出。迭代器通常被稱為輕量級對象,因為創(chuàng)建它的代價小。
面向?qū)ο蠛兔嫦蜻^程的區(qū)別
面向過程
優(yōu)點: 性能比面向?qū)ο蟾撸驗轭愓{(diào)用時需要實例化,開銷比較大,比較消耗資源;比如單片機、嵌入式開發(fā)、Linux/Unix等一般采用面向過程開發(fā),性能是最重要的因素。
缺點: 沒有面向?qū)ο笠拙S護、易復(fù)用、易擴展
面向?qū)ο?
優(yōu)點: 易維護、易復(fù)用、易擴展,由于面向?qū)ο笥蟹庋b、繼承、多態(tài)性的特性,可以設(shè)計出低耦合的系統(tǒng),使系統(tǒng)更加靈活、更加易于維護
缺點: 性能比面向過程低
通過 Scanner
Scanner input = new Scanner(System.in); String s = input.nextLine(); input.close();
通過 BufferedReader
BufferedReader input = new BufferedReader(new InputStreamReader(System.in)); String s = input.readLine();Java 面向?qū)ο缶幊倘筇匦? 封裝 繼承 多態(tài)
封裝
把一個對象的屬性私有化,同時提供一些可以被外界訪問的屬性的方法,如果屬性不想被外界訪問,我們大可不必提供方法給外界訪問。但是如果一個類沒有提供給外界訪問的方法,那么這個類也沒有什么意義了。
繼承
繼承是使用已存在的類的定義作為基礎(chǔ)建立新類的技術(shù),新類的定義可以增加新的數(shù)據(jù)或新的功能,也可以用父類的功能,但不能選擇性地繼承父類。通過使用繼承我們能夠非常方便地復(fù)用以前的代碼。
子類擁有父類非 private 的屬性和方法。
子類可以擁有自己屬性和方法,即子類可以對父類進行擴展。
子類可以用自己的方式實現(xiàn)父類的方法。
多態(tài)
指程序中定義的引用變量所指向的具體類型和通過該引用變量發(fā)出的方法調(diào)用在編程時并不確定,而是在程序運行期間才確定,即一個引用變量到底會指向哪個類的實例對象,該引用變量發(fā)出的方法調(diào)用到底是哪個類中實現(xiàn)的方法,必須在由程序運行期間才能決定。
在Java中有兩種形式可以實現(xiàn)多態(tài):繼承(多個子類對同一方法的重寫)和接口(實現(xiàn)接口并覆蓋接口中同一方法)。
方法重載是指同一個類中的多個方法具有相同的名字,但這些方法具有不同的參數(shù)列表,即參數(shù)的數(shù)量或參數(shù)類型不能完全相同
(相同名字,不同參數(shù))
方法重寫是存在子父類之間的,子類定義的方法與父類中的方法具有相同的方法名字,相同的參數(shù)表和相同的返回類型
(相同名字,相同類型)(繼承)
因為調(diào)用時不能指定類型信息
如:
float max(int a,int b) int max(int a,int b)
當(dāng)調(diào)用max(1,2)時,無法確定
抽象類(abstract)和接口(interface)選擇使用接口和抽象類的依據(jù):抽象類是對最本質(zhì)的抽象,接口是對動作的抽象
如:男人、女人是兩個類,那可以抽象出一個類,人;人可以吃東西,學(xué)習(xí)等等,這些行為就是一個個接口
都不能。抽象方法需要子類重寫,而靜態(tài)的方法是無法被重寫的;本地方式是由本地代碼實現(xiàn)的方法,而抽象方法是沒有實現(xiàn)的;synchronized和方法的實現(xiàn)細節(jié)有關(guān),抽象方法不涉及實現(xiàn)細節(jié),因此都不能。
靜態(tài)變量和實例變量的區(qū)別靜態(tài)變量:被static修飾的變量,也稱為類的變量,屬于類,不屬于類的任何一個對象,一個類不管創(chuàng)建多少對象,靜態(tài)變量在內(nèi)存只有一個拷貝,可以實現(xiàn)讓多個對象共享內(nèi)存
實例變量:必須依存某一實例,需要創(chuàng)建對象才能通過對象去訪問它。
String是引用類型,底層由char數(shù)組實現(xiàn)
String:字符串常量,在修改時布改變自身,修改等于重新生成新的自符串對象;
StringBuffer:在修改時會改變對象自身,每次操作都是對StringBuffer對象本身進行修改,不是生成新的對象,使用場景是:對字符串經(jīng)常改變情況下,主要方法:append()
線程安全:
String:定義對象后不可變,線程安全
StringBuffer:線程安全,對調(diào)用的方法加入同步鎖,執(zhí)行效率較慢,適用于多線程下操作字符串緩沖區(qū)大量數(shù)據(jù)
StringBuilderer:線程不安全,適用于單線程下操作字符串緩沖區(qū)大量數(shù)據(jù)
當(dāng)我們使用"+"時,編譯器轉(zhuǎn)換成了StringBuilder,所以不要在for語句內(nèi)使用;同時盡量不要"+"和StringBuilder一起使用
對于三者使用的總結(jié):
操作少量的數(shù)據(jù) String
單線程操作字符串緩沖區(qū)下操作大量數(shù)據(jù) StringBuilder
多線程操作字符串緩沖區(qū)下操作大量數(shù)據(jù) StringBuffer
主要作用是完成對類對象的初始化工作。可以執(zhí)行。因為一個類即使沒有聲明構(gòu)造方法也會有默認(rèn)的不帶參數(shù)的構(gòu)造方法。
== 與 equals(重要)== : 它的作用是判斷兩個對象的地址是不是相等。即,判斷兩個對象是不是同一個對象。。(基本數(shù)據(jù)類型比較的是值,引用數(shù)據(jù)類型比較的是內(nèi)存地址)
equals() : 它的作用也是判斷兩個對象是否相等。但它一般有兩種使用情況:
情況1:類沒有覆蓋 equals() 方法。則通過 equals() 比較該類的兩個對象時,等價于通過“==”比較這兩個對象。
情況2:類覆蓋了 equals() 方法。一般,我們都覆蓋 equals() 方法來兩個對象的內(nèi)容相等;若它們的內(nèi)容相等,則返回 true (即,認(rèn)為這兩個對象相等)。
public class test1 { public static void main(String[] args) { String a = new String("ab"); // a 為一個引用 String b = new String("ab"); // b為另一個引用,對象的內(nèi)容一樣 String aa = "ab"; // 放在常量池中 String bb = "ab"; // 從常量池中查找 if (aa == bb) // true System.out.println("aa==bb"); if (a == b) // false,非同一對象 System.out.println("a==b"); if (a.equals(b)) // true System.out.println("a.equals(b)"); if (42 == 42.0) { // true System.out.println("true"); } } }
說明:
String 中的 equals 方法是被重寫過的,因為 object 的 equals 方法是比較的對象的內(nèi)存地址,而 String 的 equals 方法比較的是對象的值。
當(dāng)創(chuàng)建 String 類型的對象時,虛擬機會在常量池中查找有沒有已經(jīng)存在的值和要創(chuàng)建的值相同的對象,如果有就把它賦給當(dāng)前引用。如果沒有就在常量池中重新創(chuàng)建一個 String 對象。
hashCode 與 equals (重要)如果兩個對象相等,則hashcode一定也是相同的
兩個對象相等,對兩個對象分別調(diào)用equals方法都返回true
兩個對象有相同的hashcode值,它們也不一定是相等的
因此,equals 方法被覆蓋過,則 hashCode 方法也必須被覆蓋
hashCode() 的默認(rèn)行為是對堆上的對象產(chǎn)生獨特值。如果沒有重寫 hashCode(),則該 class 的兩個對象無論如何都不會相等(即使這兩個對象指向相同的數(shù)據(jù))
length,length(),size()三者的區(qū)別length屬性:用于獲取數(shù)組長度
int ar[] = new int{1,2,3} /** * 數(shù)組用length屬性取得長度 */ int lenAr = ar.length;//此處lenAr=3 System.out.println("Arr length:"+lenAr);
length()方法:用于獲取字符串長度
String str = "Hello World Java"; /** * 字符串用length()方法取得長度 */ int lenStr = str.length();//此處lenStr=16 System.out.println("Str length():"+lenStr);
size()方法:用于獲取泛型集合有多少個元素
/** * Collection是整個類集之中單值保存的最大父接口,所以使用時需要用具體子類實例化 */ CollectionList的三個子類的特點col = new ArrayList (); col.add("Hello"); col.add("World"); col.add("Java"); /** * 類集框架用size()方法取元素個數(shù) */ int sizeCol = col.size();//此處sizeCol=3 System.out.println("Col size:"+sizeCol);
ArrayList 底層是數(shù)組,查詢快,增刪慢
LinkedList 底層是鏈表,增刪快,查詢慢
voctor 底層是數(shù)組,線程安全,增刪慢,查詢慢
如何實現(xiàn)數(shù)組和 List 之間的轉(zhuǎn)換List轉(zhuǎn)換成為數(shù)組:調(diào)用ArrayList的toArray方法。
數(shù)組轉(zhuǎn)換成為List:調(diào)用Arrays的asList方法。
思路:隊列a和b
入棧:a隊列為空,b為空,將“a,b,c,d,e”先放入a中,a進棧為“a,b,c,d,e” 出棧:將a隊列依次加入ArrayList集合c中,以倒序的方法,將c中的集合取出,放入b中,再將b隊列出列
public static void main(String[] args) { Queue隊列offer,add 區(qū)別a = new LinkedList<>(); Queue b = new LinkedList<>(); List c = new ArrayList<>(); a.offer("a"); a.offer("b"); a.offer("c"); a.offer("d"); a.offer("e"); System.out.print("進棧:"); for(String s:a){ c.add(s); System.out.print(s); } for(int i=c.size()-1;i>=0;i--){ b.offer(c.get(i)); } System.out.println(); System.out.print("出棧:"); for(String s:b){ System.out.print(s); } }
一些隊列有大小限制,因此如果想在一個滿的隊列中加入一個新項,多出的項就會被拒絕。
這時新的 offer 方法就可以起作用了。它不是對調(diào)用 add() 方法拋出一個 unchecked 異常,而只是得到由 offer() 返回的 false。
remove() 和 poll() 方法都是從隊列中刪除第一個元素。remove() 的行為與 Collection 接口的版本相似, 但是新的 poll() 方法在用空集合調(diào)用時不是拋出異常,只是返回 null。因此新的方法更適合容易出現(xiàn)異常條件的情況。
peek,element區(qū)別:element() 和 peek() 用于在隊列的頭部查詢元素。與 remove() 方法類似,在隊列為空時, element() 拋出一個異常,而 peek() 返回 null。
HashMap和HashTable的區(qū)別HashMap是線程不安全的,是Map的一個子接口,是將鍵映射到值的對象,不允許鍵值重復(fù),允許空鍵和空值,由于非線程安全,HashMap的效率要較HashTable高
HashTable是線程安全的一個集合,不允許null作為一個key或者value值,是線程安全的
異常處理在 Java 中,所有的異常都有一個共同的祖先java.lang包中的 Throwable類。
Throwable: 有兩個重要的子類:Exception(異常) 和 Error(錯誤) ,二者都是 Java 異常處理的重要子類,各自都包含大量子類。
Error(錯誤):是程序無法處理的錯誤,表示運行應(yīng)用程序中較嚴(yán)重問題。大多數(shù)錯誤與代碼編寫者執(zhí)行的操作無關(guān),而表示代碼運行時 JVM(Java 虛擬機)出現(xiàn)的問題
Exception(異常):是程序本身可以處理的異常
RuntimeException。RuntimeException 異常由Java虛擬機拋出。
NullPointerException(要訪問的變量沒有引用任何對象時,拋出該異常)
ArithmeticException(算術(shù)運算異常,一個整數(shù)除以0時,拋出該異常)
ArrayIndexOutOfBoundsException (下標(biāo)越界異常)。
SQLException,SQL異常,一般都是SQL語句錯誤
==異常和錯誤的區(qū)別:異常能被程序本身可以處理,錯誤是無法處理==
throw和throws區(qū)別throw:
throw在方法體內(nèi),表示拋出異常,執(zhí)行throw一定是拋出了某種異常
throws :
throws跟在方法聲明的后面,表示可能出現(xiàn)某種異常
如果try有返回值,就把返回值保存到局部變量中;
執(zhí)行jsr指令跳到finally語句里執(zhí)行;
執(zhí)行完finally語句后,返回之前保存在局部變量表里的值。
如果try,finally語句里均有return,忽略try的return,而使用finally的return
迭代器 Iterator迭代器是一種設(shè)計模式,它是一個對象,它可以遍歷并選擇序列中的對象,而開發(fā)人員不需要了解該序列的底層結(jié)構(gòu)。迭代器通常被稱為“輕量級”對象,因為創(chuàng)建它的代價小。
使用:
使用方法iterator()要求容器返回一個Iterator。第一次調(diào)用Iterator的next()方法時,它返回序列的第一個元素。注意:iterator()方法是java.lang.Iterable接口,被Collection繼承。
使用next()獲得序列中的下一個元素。
使用hasNext()檢查序列中是否還有元素。
使用remove()將迭代器新返回的元素刪除。
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/75685.html
摘要:操作之連接以及簡單操作下載對應(yīng)的驅(qū)動包下載創(chuàng)建一個連接類連接主機地址端口號登錄密碼連接服務(wù)器權(quán)限認(rèn)證連接完成會返回緩存鏈接錯誤查詢所有中的查詢所有的為通配符清除所有的中的是清除所有的的命令如果清理完成,會返回完整的代碼聲明對象測試地址端口密 Java操作Redis之連接以及簡單操作 1.下載對應(yīng)的驅(qū)動包 下載 jedis.jar :https://mvnrepository.com/a...
摘要:是一個由寫的存儲系統(tǒng)。是一個開源的使用語言編寫遵守協(xié)議支持網(wǎng)絡(luò)可基于內(nèi)存亦可持久化的日志型數(shù)據(jù)庫,并提供多種語言的。它通常被稱為數(shù)據(jù)結(jié)構(gòu)服務(wù)器,因為值可以是字符串哈希列表集合和有序集合等類型。 REmote DIctionary Server(Redis) 是一個由Salvatore Sanfilippo寫的key-value存儲系統(tǒng)。Redis是一個開源的使用ANSI C語言編寫、遵...
摘要:是一個由寫的存儲系統(tǒng)。是一個開源的使用語言編寫遵守協(xié)議支持網(wǎng)絡(luò)可基于內(nèi)存亦可持久化的日志型數(shù)據(jù)庫,并提供多種語言的。它通常被稱為數(shù)據(jù)結(jié)構(gòu)服務(wù)器,因為值可以是字符串哈希列表集合和有序集合等類型。 REmote DIctionary Server(Redis) 是一個由Salvatore Sanfilippo寫的key-value存儲系統(tǒng)。Redis是一個開源的使用ANSI C語言編寫、遵...
以下是Java技術(shù)棧微信公眾號發(fā)布的關(guān)于 Java 的技術(shù)干貨,從以下幾個方面匯總。 Java 基礎(chǔ)篇 Java 集合篇 Java 多線程篇 Java JVM篇 Java 進階篇 Java 新特性篇 Java 工具篇 Java 書籍篇 Java基礎(chǔ)篇 8張圖帶你輕松溫習(xí) Java 知識 Java父類強制轉(zhuǎn)換子類原則 一張圖搞清楚 Java 異常機制 通用唯一標(biāo)識碼UUID的介紹及使用 字符串...
閱讀 3224·2021-11-12 10:36
閱讀 1296·2019-08-30 15:56
閱讀 2453·2019-08-30 11:26
閱讀 562·2019-08-29 13:00
閱讀 3621·2019-08-28 18:08
閱讀 2760·2019-08-26 17:18
閱讀 1911·2019-08-26 13:26
閱讀 2440·2019-08-26 11:39