Java 计算apk大小时的NPE
我想计算手机上用户安装的应用程序的apk文件大小Java 计算apk大小时的NPE,java,android,variables,nullpointerexception,filesize,Java,Android,Variables,Nullpointerexception,Filesize,我想计算手机上用户安装的应用程序的apk文件大小 01-11 15:20:30.373: E/AndroidRuntime(17940): at android.os.AsyncTask$3.done(AsyncTask.java:200) 01-11 15:20:30.373: E/AndroidRuntime(17940): at java.util.concurrent.FutureTask$Sync.innerSetException(FutureTask.java:273)
01-11 15:20:30.373: E/AndroidRuntime(17940): at android.os.AsyncTask$3.done(AsyncTask.java:200)
01-11 15:20:30.373: E/AndroidRuntime(17940): at java.util.concurrent.FutureTask$Sync.innerSetException(FutureTask.java:273)
01-11 15:20:30.373: E/AndroidRuntime(17940): at java.util.concurrent.FutureTask.setException(FutureTask.java:124)
01-11 15:20:30.373: E/AndroidRuntime(17940): at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:307)
01-11 15:20:30.373: E/AndroidRuntime(17940): at java.util.concurrent.FutureTask.run(FutureTask.java:137)
01-11 15:20:30.373: E/AndroidRuntime(17940): at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1068)
01-11 15:20:30.373: E/AndroidRuntime(17940): at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:561)
01-11 15:20:30.373: E/AndroidRuntime(17940): at java.lang.Thread.run(Thread.java:1096)
01-11 15:20:30.373: E/AndroidRuntime(17940): Caused by: java.lang.NullPointerException
01-11 15:20:30.373: E/AndroidRuntime(17940): at com.taskmanager.sb.PackageTabActivity$AppDetails.doInBackground(PackageTabActivity.java:119)
01-11 15:20:30.373: E/AndroidRuntime(17940): at com.taskmanager.sb.PackageTabActivity$AppDetails.doInBackground(PackageTabActivity.java:1)
01-11 15:20:30.373: E/AndroidRuntime(17940): at android.os.AsyncTask$2.call(AsyncTask.java:185)
01-11 15:20:30.373: E/AndroidRuntime(17940): at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:305)
01-11 15:20:30.373: E/AndroidRuntime(17940): ... 4 more
代码是
for(int i=0;i<packs.size();i++ ) {
final PackageInfo p = packs.get(i);
if(!isSystemPackage(p))
{
String package_name = p.applicationInfo.packageName;
appname[i] =p.applicationInfo.loadLabel(getPackageManager()).toString();
try
{
getPackageSizeInfo.invoke(pm, package_name, new IPackageStatsObserver.Stub()
{
public void onGetStatsCompleted(PackageStats pStats, boolean succeeded) throws RemoteException
{
size[i] = pStats.codeSize/1024; // here error come says make i final
}});
}catch(IllegalAccessException a) {}
catch(IllegalArgumentException b) {}
catch(InvocationTargetException c) {}
}
// Log.v("apksize", "appsize = "+sSize+"appname = "+sName);
}
for(int i=0;i
NPE问题并不难解决。打开堆栈跟踪显示有问题的文件,转到它引用的行号,查看所有被取消引用的对象引用。其中一个引用为null-就这么简单。在调试器中逐步执行,您将立即看到它
如果注释的那一行是119,我会得出结论,pstats
必须为空。您认为您正确初始化了它,但JVM不同意。如果不是,请查找第119行
那些空的catch块是一个非常糟糕的主意。如果出现异常,您将永远不会知道。请始终打印堆栈跟踪,如下所示:
try {
// Do something in here
} catch (Exception e) {
e.printStackTrace();
}
NPE问题并不难解决。打开堆栈跟踪显示有问题的文件,转到它引用的行号,查看所有被取消引用的对象引用。其中一个引用为null-就这么简单。在调试器中逐步执行,您将立即看到它
如果注释的那一行是119,我会得出结论,pstats
必须为空。您认为您正确初始化了它,但JVM不同意。如果不是,请查找第119行
那些空的catch块是一个非常糟糕的主意。如果出现异常,您将永远不会知道。请始终打印堆栈跟踪,如下所示:
try {
// Do something in here
} catch (Exception e) {
e.printStackTrace();
}
如果第119行是引发NullPointerException的行,而第119行是此行:
appname[i] =p.applicationInfo.loadLabel(getPackageManager()).toString();
然后,如果第119行是引发NullPointerException的那一行,并且第119行是这一行,则需要处理p.applicationInfo.loadLabel(getPackageManager())
返回null
的情况:
appname[i] =p.applicationInfo.loadLabel(getPackageManager()).toString();
然后需要处理p.applicationInfo.loadLabel(getPackageManager())的情况
返回null
我无法理解尝试捕捉行执行的方式的行为。该类位于此处。请帮助我理解它。我不确定我是否理解您所说的内容。请参见上面的示例。我无法理解尝试捕捉行执行的方式的行为。该类位于h嗯,请帮我弄清楚。我不确定我是否明白你在说什么。请看我上面的例子。