2012-02-22 9 views
1

私はAndroidで使用され、6ヶ月前に非常に広範にテストされた以下のコードを持っています。それは正常に動作しており、問題の原因となったことはありません。 getClassContext()[1] .getName()を使用してAndroidでクラス名を取得しようとしています

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

呼び出し元のコード:この以来

Getting the class name from a static method in Java

:私は気づく、この中の誰かによって推奨されたコードの正確な同じビットがSOここに答えるで、

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

コードが書かれた、私はr14からr16に自分のAndroid SDKを更新しました。また、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) 

は基本的に、何を見ていると、私のプライベートAPIへのAndroidでのonCreateからの呼び出しです。 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

+0

これで、クリーンなマシンで作業します(他のものにもv16が必要なので、このシステムからは削除できません)。 SDKのさまざまな部分をすべてダウンロードするには驚くほど長い時間がかかります。 – AWT

+0

これまで見てきたことに基づいて、クラスの配列が導出されるコンテキストはgetClassName()内では空です。私はそれがこれのようなものだったとは思わない。 getClassName()の呼び出しの外で、私は "this"の中にたくさんのものを見ることができます。コール内で、完全に空です。 – AWT

答えて

0

私はこのコードブロックを完全に削除してしまいました。それはとにかくデバッグ出力でのみ使用されていましたが、これがなぜ失敗したのかを調べる研究に値するものではありませんでした。

関連する問題