Java基礎(整理)
java基礎:
1、==和equals的區別:
基本類型和引用類型
==用來比較值,equals是比較對象的引用,即是否指向同一個對象?
String str1 = new String("hello");
String str2 = new String("hello");
System.out.println(str1.equals(str2));
這裏為true的原因:是因為String中重寫了equals方法(原本equals方法中是比較引用地址,重寫就比較值了)
2、Java內存機制
雖然Java中沒有顯然的指針,但是它底層的實現原理還是用到到引用地址(指針)
首先內存分配上有棧、堆、常量池、方法區
無論是普通類型的變量還是引用類型的變量(俗稱實例),都可以作為局部變量,他們都可以出現在棧中。只不過普通類型的變量在棧中直接保存它所對應的值,而引用類型的變量保存的是一個指向堆區的指針,通過這個指針,就可以找到這個實例在堆區對應的對象。因此,普通類型變量只在棧區占用一塊內存,而引用類型變量要在棧區和堆區各占一塊內存。
3、Java內存回收機制
做什麽事?
發現無用的對象,回收內存空間,使該空間可被程序再次利用
什麽是垃圾?
用自己的話說,就是你創建出的一個對象,與該對象無任何相關聯的引用的時候,這個對象就叫做垃圾
垃圾回收機制的意義在哪裏?
①增強程序的健壯性,防止內存泄露,有效的利用內存空間
②意義還在於讓程序員通過學習回收機制的特性,養成一個良好的編程習慣,防止內存泄露
GC如何觸發?
①當應用程序處在空閑狀態,無線程運行時,GC會調用,以優先級最低的線程進行著垃圾回收
②當java堆內存不足的時候,GC會被調用,使得占有的內存空間得到釋放
垃圾回收機制處理不了的問題:對象之間的相互調用,導致計數不為0,所以垃圾回收器就無法回收了
4、String和StringBuffer的區別:
可變與不可變的字符串,StringBuffer性能上更優於String,還能減少垃圾回收機制的開銷,如果字符串改變過多的話,用StringBuffer可以用append方法對字符串進行追加操作,而String則需要在原來基礎上進行改變,則需要再new對象,這樣會產生多個對象,占內存的同時,也相當於多了一些無意義的操作
Mybatis裏面#和$符號的區別:
#{}會把傳入的數據當成一個字符串,會對數據自動加一個雙引號,可以防止SQL註入
而${}一般用於傳遞表明,$將傳入的數據直接顯示生成在sql中,無法防止sql註入
5、Integer和int的區別:
(1)Integer是int的包裝類;int是基本數據類型;
(2)Integer變量必須實例化後才能使用;int變量不需要;
(3)Integer實際是對象的引用,指向此new的Integer對象;int是直接存儲數據值 ;
(4)Integer的默認值是null;int的默認值是0。
6、單例模式:(如何書寫?)
保證每一次調用所用的對象只有一個,應用於一些統一的調用操作。舉例:回收站
優點:減少系統資源的浪費,一般用於需要頻繁調度的程序中,如果每一次調度都要創建一個新的實例,那麽堆內存就會產生空間的浪費。
7、方法的重寫(override)兩同兩小一大原則:
方法名相同,參數類型相同
子類返回類型小於等於父類方法返回類型,
子類拋出異常小於等於父類方法拋出異常,
子類訪問權限大於等於父類方法訪問權限。
8、加載一個類的時候優先級的高低:(類加載到內存過程)
靜態成員變量或靜態代碼塊>main方法>非靜態成員變量或非靜態代碼塊>構造方法
類的加載是由類加載器完成的,類加載器包括:
根加載器( BootStrap )、擴展加載器( Extension )、系統加載器( System )和用戶自定義類加載器( java.lang.ClassLoader 的子類)。
從 Java 2 ( JDK 1.2 )開始,類加載過程采取了父親委托機制( PDM )。 PDM 更好的保證了 Java 平臺的安全性,在該機制中, JVM 自帶的 Bootstrap 是根加載器,其他的加載器都有且僅有一個父類加載器。類的加載首先請求父類加載器加載,父類加載器無能為力時才由其子類加載器自行加載。 JVM 不會向 Java 程序提供對 Bootstrap 的引用。
下面是關於幾個類加載器的說明:
Bootstrap :一般用本地代碼實現,負責加載 JVM 基礎核心類庫( rt.jar );
Extension :從 java.ext.dirs 系統屬性所指定的目錄中加載類庫,它的父加載器是 Bootstrap ;
system class loader :又叫應用類加載器,其父類是 Extension 。它是應用最廣泛的類加載器。它從環境變量 classpath 或者系統屬性 java.class.path 所指定的目錄中記載類,是用戶自定義加載器的默認父加載器。
用戶自定義類加載器: java.lang.ClassLoader 的子類
父類委托機制是可以修改的,有些服務器就是自定義類加載器優先的。
9、九大域對象:
1、pageContext 表示頁容器 EL表達式、 標簽 、上傳
2、request 服務器端取得客戶端的信息:頭信息 、Cookie 、請求參數 ,最大用處在MVC設計模式上
3、response 服務器端回應客戶端信息:Cookie、重定向
4、session 表示每一個用戶,用於登錄驗證上
5、application 表示整個服務器
6、config 取得初始化參數,初始化參數在web.xml文件中配置
7、exception 表示的是錯誤頁的處理操作
8、page 如同this一樣,代表整個jsp頁面自身
9、out 輸出 ,但是盡量使用表達式輸出
10、URL(Uniform Resource Locator) ,統一資源定位符,能夠對因特網的資源進行定位。
URL一般有四部分組成: <協議>://<主機>:<端口>/<路徑>
現在最常用的<協議>為http協議。
<主機>是指主機在因特網上的域名。
http協議的默認<端口>為80(可以省略)。
<路徑>是指要讀取的文件的路徑。
10、方法區在JVM中也是一個非常重要的區域,它與堆一樣,是被 線程共享 的區域。 在方法區中,存儲了每個類的信息(包括類的名稱、方法信息、字段信息)、靜態變量、常量以及編譯器編譯後的代碼等。
11、JDK 常用的 package
java.lang: 這個是系統的基礎包,比如 String 等都是這裏面的,這個 package 是唯一一個可以不用 import 就可以使用的 Package。
java.io: 這裏面是所有輸入輸出有關的類,比如文件操作等
java.net: 這裏面是與網絡有關的類,比如 URL,URLConnection 等。
java.util : 這裏面是系統輔助類,特別是集合類 Collection,List,Map 等。
java.sql: 這裏面是數據庫操作的類,Connection, Statememt,ResultSet 等
12、創建泛型對象的時候,一定要指出類型變量T的具體類型。爭取讓編譯器檢查出錯誤,而不是留給JVM運行的時候拋出類不匹配的異常。
JVM如何理解泛型概念 —— 類型擦除。事實上,JVM並不知道泛型,所有的泛型在編譯階段就已經被處理成了普通類和方法。 處理方法很簡單,我們叫做類型變量T的擦除(erased) 。
總結:泛型代碼與JVM ① 虛擬機中沒有泛型,只有普通類和方法。 ② 在編譯階段,所有泛型類的類型參數都會被Object或者它們的限定邊界來替換。(類型擦除) ③ 在繼承泛型類型的時候,橋方法的合成是為了避免類型變量擦除所帶來的多態災難。 無論我們如何定義一個泛型類型,相應的都會有一個原始類型被自動提供。原始類型的名字就是擦除類型參數的泛型類型的名字。
Java基礎(整理)