2012-02-22 79 views
1

我有以下代碼,在Android上使用並在6個月前進行了相當廣泛的測試。它一直工作得很好,從來沒有成爲任何問題的原因。嘗試使用getClassContext()獲取Android上的類名稱()[1] .getName()

private static class CurrentClassGetter extends SecurityManager { 
    public String getClassName() { 
     return getClassContext()[1].getName(); 
    } 
} 

調用代碼:

//---Get my name (last part of class name) 
    System.out.println("Attempting to get class name"); 
    msSimpleName = new CurrentClassGetter().getClassName(); 

其中,我發現,是有人在此推薦的代碼完全相同的位,所以答案在這裏:

Getting the class name from a static method in Java

由於這代碼被寫入,我已經將我的Android SDK從r14更新到r16。我還下載了從API10(Android 2.3.3)到API15(Android 4.0.3)的所有新SDK包。然而,這是工作的罰款上面的代碼,現在拋出這個錯誤:

02-22 16:18:26.779: W/System.err(2593): java.lang.NullPointerException 
02-22 16:18:26.786: W/System.err(2593):  at com.company.myCompany.mobile.android.myCompanyApp$CurrentClassGetter.getClassName(myCompanyApp.java:413) 
02-22 16:18:26.806: W/System.err(2593):  at com.company.myCompany.mobile.android.myCompanyApp.monitor(myCompanyApp.java:289) 
02-22 16:18:26.806: W/System.err(2593):  at com.company.myCompany.mobile.android.myCompanyApp.monitor(myCompanyApp.java:257) 
02-22 16:18:26.826: W/System.err(2593):  at com.gomez.appname.appnameActivity.onCreate(appnameActivity.java:22) 
02-22 16:18:26.836: W/System.err(2593):  at android.app.Activity.performCreate(Activity.java:4465) 
02-22 16:18:26.846: W/System.err(2593):  at android.app.InstAppentation.callActivityOnCreate(InstAppentation.java:1049) 
02-22 16:18:26.856: W/System.err(2593):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1920) 
02-22 16:18:26.866: W/System.err(2593):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1981) 
02-22 16:18:26.876: W/System.err(2593):  at android.app.ActivityThread.access$600(ActivityThread.java:123) 
02-22 16:18:26.876: W/System.err(2593):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1147) 
02-22 16:18:26.896: W/System.err(2593):  at android.os.Handler.dispatchMessage(Handler.java:99) 
02-22 16:18:26.896: W/System.err(2593):  at android.os.Looper.loop(Looper.java:137) 
02-22 16:18:26.906: W/System.err(2593):  at android.app.ActivityThread.main(ActivityThread.java:4424) 
02-22 16:18:26.926: W/System.err(2593):  at java.lang.reflect.Method.invokeNative(Native Method) 
02-22 16:18:26.926: W/System.err(2593):  at java.lang.reflect.Method.invoke(Method.java:511) 
02-22 16:18:26.946: W/System.err(2593):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784) 
02-22 16:18:26.946: W/System.err(2593):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551) 
02-22 16:18:26.956: W/System.err(2593):  at dalvik.system.NativeStart.main(Native Method) 

基本上,你看什麼是從的onCreate Android中我的私人API的調用。在API中,它試圖使用上面的代碼獲取當前類名。

目標API版本是8,現在是8(Android v2.2),所以根本沒有改變。 Java合規性級別1.6,運行Java 1.6.0_24 64位。

有沒有人知道爲什麼getClassContext()[1] .getName()會突然拋出一個像這樣的NullPointerException,當它工作之前?

+0

您是否嘗試從您的計算機上刪除Android SDK v16並再次安裝v14以確認SDK版本是唯一區別? – Fixpoint 2012-02-23 17:16:34

+0

現在在一臺乾淨的機器上工作(我還需要其他東西的v16,所以我不能從這個系統中刪除它)。下載所有不同部分的SDK需要花費相當長的時間。 – AWT 2012-02-23 20:16:02

+0

根據我目前所看到的,派生類數組的上下文在getClassName()中是空的。我不認爲它曾經是這樣的。除了調用getClassName()之外,我可以在「this」中看到很多東西。在通話中,完全空了。 – AWT 2012-02-23 20:40:46

回答

0

沒有解決的問題,我最終完全刪除了這塊代碼。無論如何,它只被用於調試輸出,並且不值得研究去弄清楚爲什麼這是失敗的。

相關問題