我在android中获取助手类有一点问题。我有3个类A,B,C。 B扩展A和C我试图在B中使用C中的方法,但每次我尝试使用它时都会抛出一个NullPointerException。
这是我正在使用的代码:
在A班我有这个:
public class A {
//declaration from class C
C newC;
}
在C班我有:
public class C {
static Context context;
String version = "";
public static int strVerToIntVer(String strLen){
String newStr = strLen.replace(".", "");
int i=Integer.parseInt(newStr);
return i;
}
public static String getPackageVersion(){
try {
PackageManager pm = context.getPackageManager();
PackageInfo packageInfo = pm.getPackageInfo(context.getPackageName(), 0);
version = packageInfo.versionName;
} catch (NameNotFoundException e) {
e.printStackTrace();
}
return version;
}
public static boolean checkClientApiVer(String clientApiVer){
int s = C.strVerToIntVer(clientApiVer);
int c = C.strVerToIntVer(getPackageVersion());
return (c>=s);
}
}
在B班我有:
public class B extends A {
C newC;
serverApiVer = jsonObj.getString("server_api_ver");
Log.w("SERVER API VER","SHOW SERVER API VERSION : "+serverApiVer);
C.checkClientApiVer(serverApiVer);
}
并且这一行:C.checkClientApiVer(serverApiVer);
给我一个NullPointerException,我仍然不知道如何解决这个问题。
LogCat:
09 -
15 15:47:37.752: WARN/System.err(8150): java.lang.NullPointerException
09-15 15:47:37.752: WARN/System.err(8150): at com.stampii.stampii.comm.rpc.C.getPackageVersion(RPCCommunicator.java:1035)
09-15 15:47:37.752: WARN/System.err(8150): at com.stampii.stampii.comm.rpc.C.checkClientApiVer(RPCCommunicator.java:1048)
09-15 15:47:37.752: WARN/System.err(8150): at com.stampii.stampii.comm.rpc.B.executeBefore(InfoStartRPCPacket.java:103)
09-15 15:47:37.752: WARN/System.err(8150): at com.stampii.stampii.user.UserLogin$2.onClick(UserLogin.java:215)
09-15 15:47:37.752: WARN/System.err(8150): at android.view.View.performClick(View.java:2408)
09-15 15:47:37.752: WARN/System.err(8150): at android.view.View$PerformClick.run(View.java:8817)
09-15 15:47:37.752: WARN/System.err(8150): at android.os.Handler.handleCallback(Handler.java:587)
09-15 15:47:37.752: WARN/System.err(8150): at android.os.Handler.dispatchMessage(Handler.java:92)
09-15 15:47:37.762: WARN/System.err(8150): at android.os.Looper.loop(Looper.java:144)
09-15 15:47:37.762: WARN/System.err(8150): at android.app.ActivityThread.main(ActivityThread.java:4937)
09-15 15:47:37.762: WARN/System.err(8150): at java.lang.reflect.Method.invokeNative(Native Method)
09-15 15:47:37.762: WARN/System.err(8150): at java.lang.reflect.Method.invoke(Method.java:521)
09-15 15:47:37.762: WARN/System.err(8150): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
09-15 15:47:37.762: WARN/System.err(8150): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
09-15 15:47:37.762: WARN/System.err(8150): at dalvik.system.NativeStart.main(Native Method)
09-15 15:47:37.762: WARN/ERROR(8150): Error - java.lang.NullPointerException
有什么建议吗?
答案 0 :(得分:0)
你的上下文是空的。
你会知道的你会看到堆栈跟踪。
此外,未声明版本。它甚至不应该编译。
在抛出NPE的方法中有3个变量。它必须是其中之一。所以。您的上下文是null(未在任何地方初始化),或者您的packagemanager为null(非常不可能),或者您的packageinfo为null(不太可能,因为它应该抛出异常)。
我建议你测试这三个,特别是上下文。
(另外,你的版本字段不是静态的,不能从getPackageVersion访问,这是静态的