[TOC]
# 面向?qū)ο笕筇匦?封裝、繼承、多態(tài)。
* 封裝隱藏了類的內(nèi)部實(shí)現(xiàn)機(jī)制,可以在不影響使用的情況下改變類的內(nèi)部結(jié)構(gòu),同時也保護(hù)了數(shù)據(jù)
* 繼承可以重用父類代碼,實(shí)現(xiàn)代碼復(fù)用和可擴(kuò)展的效果
* 多態(tài)指對象的一個方法在調(diào)用時可以有多種狀態(tài),即父類引用可以持有子類對象
* 多態(tài)實(shí)現(xiàn)的兩種形式:基于繼承重寫、基于接口
* 多態(tài)存在的三個條件:繼承、重寫、父類引用持有子類對象
* 非靜態(tài)成員方法的調(diào)用:編譯看父類,運(yùn)行看子類
* 多態(tài)優(yōu)點(diǎn):不用創(chuàng)建一堆子類對象的引用;多態(tài)缺點(diǎn):不能使用子類特有的成員屬性和成員方法
# 靜態(tài)綁定和動態(tài)綁定
* 綁定指一個方法的調(diào)用與方法所在的類關(guān)聯(lián)起來
* 靜態(tài)綁定:編譯過程中編譯器已經(jīng)準(zhǔn)確的知道這個方法屬于哪個類了
* 動態(tài)綁定:需要在運(yùn)行時根據(jù)對象具體的類型來綁定,來選擇調(diào)用哪個類的方法
* private方法、static方法、final方法、構(gòu)造器方法都是靜態(tài)綁定的;其他方法全部為動態(tài)綁定
# 方法的重載與重寫
* 重載指在一個里面,方法名字相同,參數(shù)不同,返回類型可相同也可不同。常用于構(gòu)造器重載
* 重寫指子類對父類允許訪問的方法的實(shí)現(xiàn)過程進(jìn)行重新編寫,返回值和形參都不能變
# 本地變量、實(shí)例變量以及類變量之間的區(qū)別
* 本地變量就是局部變量,定義在方法內(nèi)部或者方法的形參中
* 實(shí)例變量為為非靜態(tài)變量,隸屬于對象,每一個對象的實(shí)例變量都不同
* 類變量為靜態(tài)變量,隸屬于類
# 形參與實(shí)參
* 形參是定義方法時使用的參數(shù),出現(xiàn)在方法定義中,在整個方法內(nèi)可以使用,離開該方法不能使用。
* 實(shí)參是用于調(diào)用方法時傳遞給方法的參數(shù)。
# 引用分類
1、強(qiáng)引用:是使用最普遍的引用。如果一個對象具有強(qiáng)引用,那垃圾回收器絕不會回收它。
2、軟引用:如果內(nèi)存空間足夠,垃圾回收器就不會回收軟引用對象;如果內(nèi)存空間不足,就會回收軟引用對象。
3、弱引用:弱引用對象比軟引用對象生命周期更短,垃圾回收器掃描時一旦發(fā)現(xiàn)弱引用對象,就會回收它。垃圾回收器優(yōu)先級不高,所以不一定很快發(fā)現(xiàn)弱引用對象。
4、虛引用:虛引用對象就和沒有被引用一樣,任何時候都可能被垃圾回收器回收。一般用于跟蹤對象被垃圾回收器回收的過程,如開源庫LeakCanary。
# 值傳遞與引用傳遞
1、Java總是采用按值調(diào)用,方法得到的是參數(shù)值的一個拷貝。
2、一個方法不能改變其參數(shù)的值,如果是基本類型參數(shù)不能改變參數(shù)的值,如果是對象參數(shù)不能改變參數(shù)的引用指向(但可以改變所指向?qū)ο蟮膶傩裕?
# final關(guān)鍵字的理解
1、final的意思是【無法改變的】、【最終的】,可以修飾非抽象類、非抽象類的成員變量和成員方法
2、final類不能被繼承,沒有子類,其中的方法默認(rèn)是final的
3、final方法不能被重寫,但可以被繼承(final不能用于修飾構(gòu)造方法)
4、final成員變量表示常量,只能被賦值一次,賦值后不再改變。
5、使用final聲明基礎(chǔ)數(shù)據(jù)類型時,數(shù)值恒定不變;使用final聲明對象引用時,引用的對象恒定不變,但對象的數(shù)據(jù)可變;使用final聲明數(shù)組類型時,引用的數(shù)組恒定不變,但數(shù)組內(nèi)的數(shù)據(jù)可變。
優(yōu)點(diǎn):
1、編譯器遇到final方法時會轉(zhuǎn)入內(nèi)嵌機(jī)制,提高效率。
2、可以安全的在多線程環(huán)境下共享,不需要額外的同步開銷。
# Java類加載的時機(jī)
1、加載順序:加載 -> 驗(yàn)證 -> 準(zhǔn)備 -> 解析 -> 初始化 -> 使用 -> 卸載
2、解析有時可以在初始化之后進(jìn)行
3、Java虛擬機(jī)沒規(guī)定什么時候進(jìn)行加載,但規(guī)定以下幾種情況需要進(jìn)行初始化,當(dāng)然初始化前的那幾步操作需要在初始化前完成。
a、new一個實(shí)例對象時,讀取或設(shè)置一個類的靜態(tài)字段時,調(diào)用一個類的靜態(tài)方法時
b、反射調(diào)用時,如果沒初始化需要觸發(fā)初始化
c、初始化一個類時,如果其父類還未初始化,需要先觸發(fā)父類的初始化
d、虛擬機(jī)啟動時,會先初始化主類
# Java類加載調(diào)用順序
1、基類靜態(tài)代碼塊、基類靜態(tài)成員變量(優(yōu)先級相同,按代碼出現(xiàn)順序依次執(zhí)行)(只有第一次加載類時執(zhí)行)
2、派生類靜態(tài)代碼塊、派生類靜態(tài)成員變量(優(yōu)先級相同,按代碼出現(xiàn)順序依次執(zhí)行)(只有第一次加載類時執(zhí)行)
3、基類普通代碼塊、基類普通成員變量(優(yōu)先級相同,按代碼出現(xiàn)順序依次執(zhí)行)
4、基類構(gòu)造函數(shù)
5、派生類普通代碼塊、派生類普通成員變量(優(yōu)先級相同,按代碼出現(xiàn)順序依次執(zhí)行)
6、派生類構(gòu)造函數(shù)
# 抽象類和接口區(qū)別
* 抽象類可以包含抽象方法和具體方法;接口只能包含抽象方法
* 抽象類方法可使用public、protected、private修飾符;接口方法默認(rèn)使用public static修飾,成員變量默認(rèn)使用public static final修飾
* 一個抽象類只能繼承一個父類;但一個接口可以繼承多個父接口
* 相同點(diǎn):二者都不可以實(shí)例化
# 為什么匿名內(nèi)部類使用局部引用要用final
1、匿名內(nèi)部類屬于一種局部內(nèi)部類。
2、編譯后局部內(nèi)部類中會有一個成員變量,是對外部局部變量的引用的拷貝,在局部內(nèi)部類使用外部局部變量值時都是通過這個引用進(jìn)行的。
3、為避免這個成員變量的值(引用的對象)被外部類的方法修改,導(dǎo)致內(nèi)部類在使用時得到的值不一樣,需要使用final讓該成員變量不可變。
4、局部變量位于方法內(nèi)部,在虛擬機(jī)的棧上,意味著這個變量無法進(jìn)行共享,匿名內(nèi)部類無法直接訪問,只能通過值傳遞的方式,傳遞給匿名內(nèi)部類。
5、而類的成員變量在虛擬機(jī)的堆上,內(nèi)部類可以直接獲取這個變量,故類的成員變量不需要聲明為final內(nèi)部類就可訪問。
# 什么是匿名內(nèi)部類
1、匿名內(nèi)部類即沒有名字的內(nèi)部類,只可被使用一次
2、使用匿名內(nèi)部類前提條件:必須繼承自一個父類或?qū)崿F(xiàn)一個接口
3、語法格式為 new 父類構(gòu)造器(參數(shù)列表)|實(shí)現(xiàn)接口(){}
4、直接將抽象類的方法或者接口方法在大括號中實(shí)現(xiàn),可以省略一個類的書寫
5、匿名內(nèi)部類中不能定義構(gòu)造方法,但可以使用初始化語塊代替構(gòu)造方法
- 導(dǎo)讀
- Java知識
- Java基本程序設(shè)計(jì)結(jié)構(gòu)
- 【基礎(chǔ)知識】Java基礎(chǔ)
- 【源碼分析】Okio
- 【源碼分析】深入理解i++和++i
- 【專題分析】JVM與GC
- 【面試清單】Java基本程序設(shè)計(jì)結(jié)構(gòu)
- 對象與類
- 【基礎(chǔ)知識】對象與類
- 【專題分析】Java類加載過程
- 【面試清單】對象與類
- 泛型
- 【基礎(chǔ)知識】泛型
- 【面試清單】泛型
- 集合
- 【基礎(chǔ)知識】集合
- 【源碼分析】SparseArray
- 【面試清單】集合
- 多線程
- 【基礎(chǔ)知識】多線程
- 【源碼分析】ThreadPoolExecutor源碼分析
- 【專題分析】volatile關(guān)鍵字
- 【面試清單】多線程
- Java新特性
- 【專題分析】Lambda表達(dá)式
- 【專題分析】注解
- 【面試清單】Java新特性
- Effective Java筆記
- Android知識
- Activity
- 【基礎(chǔ)知識】Activity
- 【專題分析】運(yùn)行時權(quán)限
- 【專題分析】使用Intent打開三方應(yīng)用
- 【源碼分析】Activity的工作過程
- 【面試清單】Activity
- 架構(gòu)組件
- 【專題分析】MVC、MVP與MVVM
- 【專題分析】數(shù)據(jù)綁定
- 【面試清單】架構(gòu)組件
- 界面
- 【專題分析】自定義View
- 【專題分析】ImageView的ScaleType屬性
- 【專題分析】ConstraintLayout 使用
- 【專題分析】搞懂點(diǎn)九圖
- 【專題分析】Adapter
- 【源碼分析】LayoutInflater
- 【源碼分析】ViewStub
- 【源碼分析】View三大流程
- 【源碼分析】觸摸事件分發(fā)機(jī)制
- 【源碼分析】按鍵事件分發(fā)機(jī)制
- 【源碼分析】Android窗口機(jī)制
- 【面試清單】界面
- 動畫和過渡
- 【基礎(chǔ)知識】動畫和過渡
- 【面試清單】動畫和過渡
- 圖片和圖形
- 【專題分析】圖片加載
- 【面試清單】圖片和圖形
- 后臺任務(wù)
- 應(yīng)用數(shù)據(jù)和文件
- 基于網(wǎng)絡(luò)的內(nèi)容
- 多線程與多進(jìn)程
- 【基礎(chǔ)知識】多線程與多進(jìn)程
- 【源碼分析】Handler
- 【源碼分析】AsyncTask
- 【專題分析】Service
- 【源碼分析】Parcelable
- 【專題分析】Binder
- 【源碼分析】Messenger
- 【面試清單】多線程與多進(jìn)程
- 應(yīng)用優(yōu)化
- 【專題分析】布局優(yōu)化
- 【專題分析】繪制優(yōu)化
- 【專題分析】內(nèi)存優(yōu)化
- 【專題分析】啟動優(yōu)化
- 【專題分析】電池優(yōu)化
- 【專題分析】包大小優(yōu)化
- 【面試清單】應(yīng)用優(yōu)化
- Android新特性
- 【專題分析】狀態(tài)欄、ActionBar和導(dǎo)航欄
- 【專題分析】應(yīng)用圖標(biāo)、通知欄適配
- 【專題分析】Android新版本重要變更
- 【專題分析】唯一標(biāo)識符的最佳做法
- 開源庫源碼分析
- 【源碼分析】BaseRecyclerViewAdapterHelper
- 【源碼分析】ButterKnife
- 【源碼分析】Dagger2
- 【源碼分析】EventBus3(一)
- 【源碼分析】EventBus3(二)
- 【源碼分析】Glide
- 【源碼分析】OkHttp
- 【源碼分析】Retrofit
- 其他知識
- Flutter
- 原生開發(fā)與跨平臺開發(fā)
- 整體歸納
- 狀態(tài)及狀態(tài)管理
- 零碎知識點(diǎn)
- 添加Flutter到現(xiàn)有應(yīng)用
- Git知識
- Git命令
- .gitignore文件
- 設(shè)計(jì)模式
- 創(chuàng)建型模式
- 結(jié)構(gòu)型模式
- 行為型模式
- RxJava
- 基礎(chǔ)
- Linux知識
- 環(huán)境變量
- Linux命令
- ADB命令
- 算法
- 常見數(shù)據(jù)結(jié)構(gòu)及實(shí)現(xiàn)
- 數(shù)組
- 排序算法
- 鏈表
- 二叉樹
- 棧和隊(duì)列
- 算法時間復(fù)雜度
- 常見算法思想
- 其他技術(shù)
- 正則表達(dá)式
- 編碼格式
- HTTP與HTTPS
- 【面試清單】其他知識
- 開發(fā)歸納
- Android零碎問題
- 其他零碎問題
- 開發(fā)思路
