談JAVA靜態載入的兩種方式
你對JAVA靜態載入了解嗎?如果你了解,你了解多少呢?下面就為你介紹JAVA的靜態載入。
JAVA靜態載入的時候需要思索到安全要素,這個問題就是我們必須解決的問題。下面我們就看看如何才能更好的解決相關安全下面的問題。 希望大家從中吸取相關的知識。
我們試想一下, 假如不運用這種委托模式,那我們就可以隨時運用自定義的String來靜態替代java中心api中定義類型,這樣會存在十分大的安全隱患,而雙親委托的方式,就可以防止這種情況,因為String已經在啟動時被加載,所以用戶自定義類是無法加載一個自定義的ClassLoader。
java靜態載入class的兩種方式:
implicit隱式, 即應用實例化才載入的特性來java靜態載入入class。
explicit顯式方式, 又分兩種方式:
java. lang. Class的forName()辦法
java. lang. ClassLoader的loadClass()辦法
用Class. forName加載類
Class. forName運用的是被調用者的類加載器來加載類的。
這種特性, 證明了java類加載器中的稱號空間是***的, 不會相互攪擾。
即在一般情況下, 保證同一個類中所關聯的其他類都是由以后類的類加載器所加載的。
以下是代碼片段:
- public static Class forName(String className)
- throws ClassNotFoundException {
- return forName0(className, true , ClassLoader. getCallerClassLoader());
- }
- /** Called after security checks have been made. */
- private static native Class forName0(String name, boolean initialize,
- ClassLoader loader)
- throws ClassNotFoundException; Java代碼
- public static Class forName(String className)
- throws ClassNotFoundException {
- return forName0(className, true , ClassLoader. getCallerClassLoader());
- }
- /** Called after security checks have been made. */
- private static native Class forName0(String name, boolean initialize,
- ClassLoader loader)
- throws ClassNotFoundException;
下面中 ClassLoader. getCallerClassLoader 就是失掉調用以后forName辦法的類的類加載器static塊在什么時候執行?
當調用forName(String)載入class時執行, 假如調用ClassLoader. loadClass并不會執行. forName(String, false, ClassLoader)時也不會執行,假如載入Class時沒有執行static塊則在***次實例化時執行. 比如new , Class. newInstance()操作static塊僅執行一次, 各個java類由哪些classLoader加載?
java類可以通過實例. getClass. getClassLoader()得知接口由AppClassLoader(System ClassLoader, 可以由ClassLoader. getSystemClassLoader()取得實例)載入ClassLoader。類由bootstrap loader載入NoClassDefFoundError和ClassNotFoundException。
NoClassDefFoundError:當java源文件已編譯成. class文件, 但是ClassLoader在運行期間在其搜索途徑load某個類時, 沒有找到. class文件則報這個錯。
ClassNotFoundException:試圖通過一個String變量來創建一個Class類時不成功則拋出這個異常。
以上就是對java靜態載入的介紹,希望對你有幫助。
【編輯推薦】