Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/android/209.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 计算apk大小时的NPE_Java_Android_Variables_Nullpointerexception_Filesize - Fatal编程技术网

Java 计算apk大小时的NPE

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)

我想计算手机上用户安装的应用程序的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 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嗯,请帮我弄清楚。我不确定我是否明白你在说什么。请看我上面的例子。