java 静态代码块_关于Java你不知道的那些事之代码块
前言
普通代碼塊:在方法或語句中出現的{},就被稱為代碼塊
靜態代碼塊:靜態代碼塊有且僅加載一次,也就是在這個類被加載至內存的時候
普通代碼塊和一般語句執行順序由他們在代碼中出現的次序決定,先出現先執行
代碼一
/**對于上述方法,我們一下就能看出它的輸出結果
普通代碼塊中的變量X=11 普通代碼塊中的變量y=13 主方法中的變量x=12代碼二
而對于下面的代碼,我們調用了類的初始化,同時在類里也寫了兩個代碼塊
/**這里需要談的就是,類加載機制了,因為我們都知道,當我們實例化一個類的時候
new CodeBlock02();啟動調用的就是這個類的構造方法,但是比構造方法更上一級的是跟本構造方法在同一個類的代碼塊,因此
代碼塊的優先級比構造方法高構造代碼塊在每次創建對象的時候都會被調用,并且構造代碼塊的執行次序優先于構造方法
代碼三
/**輸出結果
CodeBlock03的靜態代碼塊33333 我是主類====== Code的靜態代碼塊33333 Code的構造代碼塊22222 Code的構造方法1111 ====== Code的構造代碼塊22222 Code的構造方法1111 ====== CodeBlock03的構造代碼塊22222 CodeBlock03的構造方法33333從上面的結果可以看出,但這個類被加載到內存的時候,首先需要執行的是靜態方法,也就是static方法在類被實例化之前,就已經完成了,和以后的實例化都沒有關系了,因此我們能夠看到,被第一個輸出,同時靜態代碼塊有且僅加載一次,但我們需要運行main方法的時候,就需要等CodeBlock03加載好,因此能夠看到下面的輸出了
CodeBlock03的靜態代碼塊33333同時但我們實例化 Code類的時候,這個類也會首先被加載到內存中,然后也是首先運行靜態代碼塊
Code的靜態代碼塊33333再次實例化的時候,因此該類已經在內存中,所以不再運行靜態代碼塊了
Code的構造代碼塊22222 Code的構造方法1111最后在實例化CodeBlock03,因為CodeBlock03也已經被加載內存中
CodeBlock03的構造代碼塊22222 CodeBlock03的構造方法33333代碼四
/**輸出結果
我是主類====== 我是父親靜態代碼塊 我是兒子靜態代碼塊 我是父親代碼塊 我是父親構造 我是兒子代碼塊 我是兒子構造 ====== 我是父親代碼塊 我是父親構造 我是兒子代碼塊 我是兒子構造 ====== 我是父親代碼塊 我是父親構造任何一個類被加載,必須加載這個類的靜態代碼塊
同時如果存在父子關系的時候,調用子類的構造方法,同時子類的構造方法,在最頂部會調用super()也就是父類的構造方法,一般這個是被省略的
public所以在子類初始化之前,還需要調用父類構造,所以父類需要加載進內存,也就是從父到子,靜態執行,并且只加載一次
我是父親靜態代碼塊 我是兒子靜態代碼塊然后父類在進行實例化,在調用構造方法之前,需要調用本類的代碼塊
我是父親代碼塊 我是父親構造最后父類初始化成功后,在調用子類的
我是兒子代碼塊 我是兒子構造在執行第二次的 new Son()的時候,因為該類已經被裝載在內存中了,因此靜態代碼塊不需要執行,我們只需要從父到子執行即可
我是父親代碼塊 我是父親構造 我是兒子代碼塊 我是兒子構造同理在執行new Father()的時候也是一樣的,只需要執行Father的實例化
我是父親代碼塊 我是父親構造原作者:輕狂書生FS
原文鏈接:關于Java你不知道的那些事之代碼塊_輕狂書生FS的博客-CSDN博客
原出處:CSDN博客
侵刪 創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎
總結
以上是生活随笔為你收集整理的java 静态代码块_关于Java你不知道的那些事之代码块的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: python批量处理excel文本改为数
- 下一篇: React Portals的使用