我有以下代码,在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();
其中,我发现,是有人在此推荐的代码完全相同的位,所以答案在这里:
由于这代码被写入,我已经将我的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,当它工作之前?
2012-02-22
AWT
+0
您是否尝试从您的计算机上删除Android SDK v16并再次安装v14以确认SDK版本是唯一区别? –
2012-02-23 17:16:34
+0
现在在一台干净的机器上工作(我还需要其他东西的v16,所以我不能从这个系统中删除它)。下载所有不同部分的SDK需要花费相当长的时间。 –
2012-02-23 20:16:02
+0
根据我目前所看到的,派生类数组的上下文在getClassName()中是空的。我不认为它曾经是这样的。除了调用getClassName()之外,我可以在“this”中看到很多东西。在通话中,完全空了。 –
2012-02-23 20:40:46