xylz,imxylz

          關注后端架構、中間件、分布式和并發(fā)編程

             :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
            111 隨筆 :: 10 文章 :: 2680 評論 :: 0 Trackbacks

          我在CentOS release 5.3 (Final)遇到一種情況:

          一個類的所有public static final字段中,按照定義的從上往下順序,到一個字段為止,此字段的上面的所有字段都能訪問,此字段下面(包括子字段)都不能訪問。

          具體是這樣的:resin環(huán)境下一個jsp訪問一個類的某個字段,在web請求此jsp的時候被告知編譯jsp失敗,原因是:cannot find symbol。并指明了此類的哪一個字段。具體分析后發(fā)現(xiàn)此字段的上面所有字段都可以訪問,此字段的下面字段(包括自己)都不能訪問。但是詭異的是,在jsp中使用Class.getField()或者getFields()遍歷是可以拿到此字段的,并且此字段是完整的,可用的。

          也就是說JVM實例化了一個類,完成了所有字段的初始化,但是在將所有字段設置為對外可見時失敗了,導致一部分字段對外是不可見的,但是此類卻成功初始化,并對外可用了。這里所說的對外可見不是說字段設置為非public,而是類外根本就看不到,因為如果是非public的話會得到一個訪問修飾符不可見的錯誤,但是現(xiàn)在得到是不存在此符號。這只是我的猜想,并不一定正確。

          我的JVM版本如下:

          java version "1.6.0_10"
          Java(TM) SE Runtime Environment (build 1.6.0_10-b33)
          Java HotSpot(TM) 64-Bit Server VM (build 11.0-b15, mixed mode)

          其中resin比較老,是3.0.21 pro版本。特別說明的是,這種情況是偶爾才出現(xiàn),重啟resin就消失了,所有字段可以正常訪問。我一共遇到了兩次,目前仍然不知道是JVM的bug還是resin的bug。

           

          第二個詭異的事情是,聽同事(兩個以上人看過現(xiàn)象)描述他寫了一個單例,如下:

          public class Singleton {

              private static final Singleton instance = new Singleton();

              private Singleton() {
              }

              public static Singleton getInstance() {
                  return instance;
              }
          }

          然后去調(diào)用getInstance(),結果居然得到一個null。特別說明的是 沒有ClassNotFoundException異常,沒有java.lang.ExceptionInInitializerError異常,也沒有java.lang.NoClassDefFoundError異常,沒有任何異常,是一個真真正正的null。

          當然了,比較詭異的是重啟JVM就沒有此現(xiàn)象了。此現(xiàn)象我沒有重現(xiàn)過,也沒有看到過,只是道途聽說,不好過多評論。

           

          以上兩個問題有誰遇到過么?

          難道是RP問題?靈異事件?JVM BUG?



          ©2009-2014 IMXYLZ |求賢若渴
          posted on 2010-08-12 00:54 imxylz 閱讀(3136) 評論(14)  編輯  收藏 所屬分類: J2EE

          評論

          # re: 這是JVM的Bug么?誰遇到下面的情況? 2010-08-12 07:41 Robin's Java World
          按你說的,確實夠靈異的。  回復  更多評論
            

          # re: 這是JVM的Bug么?誰遇到下面的情況? 2010-08-12 08:31 蒲田
            public static Singleton getInstance() {
              if (instance == null)
                instance = new Singleton();
              return instance;
            }

          這是我在老一輩手上學到的教訓,說這是良好習慣  回復  更多評論
            

          # re: 這是JVM的Bug么?誰遇到下面的情況? 2010-08-12 08:53 liping
          這算哪門子良好習慣  回復  更多評論
            

          # re: 這是JVM的Bug么?誰遇到下面的情況? 2010-08-12 09:38 xylz
          @蒲田
          一看就是新手  回復  更多評論
            

          # re: 這是JVM的Bug么?誰遇到下面的情況? 2010-08-12 09:53 xylz
          @xylz
          參考《單例模式完全解析》
          http://www.aygfsteel.com/xylz/archive/2009/12/18/306622.html  回復  更多評論
            

          # re: 這是JVM的Bug么?誰遇到下面的情況? 2010-08-12 10:31 bingo
          同意。static 字段會在構造器之前執(zhí)行。   回復  更多評論
            

          # re: 這是JVM的Bug么?誰遇到下面的情況? 2010-08-12 10:32 bingo
          @liping
          確實很好,用到時候在加載。除非你要求更快訪問且內(nèi)存夠大  回復  更多評論
            

          # re: 這是JVM的Bug么?誰遇到下面的情況? 2010-08-12 14:43 蒲田
          抱歉是我沒看清楚 這問題  回復  更多評論
            

          # re: 這是JVM的Bug么?誰遇到下面的情況? 2010-08-12 14:57 蒲田
          我原以為是Debug 所以提出"如此見解",自己也曾遇過這問題,就理論來說是不需要多我那個檢查,但是當時詢問長輩的,卻被責備:"就塞進去一個檢查",所以就不曾思考這問題了  回復  更多評論
            

          # re: 這是JVM的Bug么?誰遇到下面的情況? 2010-08-12 15:10 shaiehv
          曙海嵌入式學院提供以下課程的培訓--中國最大的FPGA,DSP和3G手機通信培訓機構:
          FPGA培訓,DSP培訓,MTK培訓,Android培訓,Symbian培訓,iPhone培訓,單片機培訓,Candence PCB培訓,Vxworks培訓等。
          網(wǎng)址: http://www.51qianru.cn
          上海總部電話:021-51875830 深圳:0755-61280252 北京:010-51292078 南京:025-68662821  回復  更多評論
            

          # re: 這是JVM的Bug么?誰遇到下面的情況? 2010-08-15 19:38 ouyang
          第2個問題,是否存在多線程并發(fā)訪問的情況?
          如果存在多線程,是有可能取得null,不是jvm的問題。
          一個線程在初始化class后,調(diào)用new Singleton(); 時被掛起;這個時候另個線程訪問 getInstance(),但是這個時候instance 是存在的,jvm給這個做了初始化,但是還沒有分配好對象值。所以instance就是null了。  回復  更多評論
            

          # re: 這是JVM的Bug么?誰遇到下面的情況? 2010-08-15 20:50 xylz
          @ouyang
          JAVA規(guī)范保證一個類的static字段和static塊運行結束后才能被調(diào)用。  回復  更多評論
            

          # re: 這是JVM的Bug么?誰遇到下面的情況? 2010-08-18 21:29 ouyang
          @xylz
          是的,多線程情況下也不應該出現(xiàn)這樣的問題。  回復  更多評論
            

          # re: 這是JVM的Bug么?誰遇到下面的情況? 2010-09-02 10:20 bonamana
          加一個 volatile 就好了吧

          java內(nèi)存模型的一個“bug“或者什么,指令重排,返回了對象,但是對象尚未初始化。

          多線程出現(xiàn)的  回復  更多評論
            


          ©2009-2014 IMXYLZ
          主站蜘蛛池模板: 资阳市| 通许县| 东宁县| 石棉县| 江达县| 巴青县| 百色市| 方山县| 北辰区| 杨浦区| 甘洛县| 辽源市| 仙桃市| 曲靖市| 辽阳市| 兰溪市| 吴堡县| 平果县| 玉环县| 丰镇市| 汪清县| 桦甸市| 富蕴县| 崇文区| 左贡县| 临江市| 太白县| 蛟河市| 鄂州市| 东乌珠穆沁旗| 咸阳市| 七台河市| 攀枝花市| 鹤壁市| 拉萨市| 滨海县| 肇庆市| 仙桃市| 永川市| 独山县| 准格尔旗|