INSTALL_FAILED_INSUFFICIENT_STORAGE错误是每个Android开发人员的烦恼。这与应用程序大小或可用存储空间大小无关。重新启动目标设备可以短暂地修复问题,但它很快就会回来。人们在留言板上发帖询问为什么会出现这个问题,但令人沮丧的是,谷歌的人对这个问题保持沉默。
有一个简单的变通办法。如果您的测试设备运行的是Android 2.2或更高版本,那么将Android:installLocation属性添加到应用程序的清单文件中,值为“preferExternal”。这将迫使应用程序安装在设备的外部存储设备上,比如手机的SD卡。
例如:
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.andrewsmith.android.darkness"
android:installLocation="preferExternal"
这更像是一种创可贴,而不是补救措施,如果你想要完成的应用程序安装在设备的内部内存中,这可能不太理想。但它至少会让开发过程不那么令人沮丧。
模拟器上的一个相关问题是/data分区中没有任何剩余空间。
例如,
% adb shell df
Filesystem Size Used Free Blksize
/dev 252M 32K 252M 4096
/mnt/asec 252M 0K 252M 4096
/mnt/obb 252M 0K 252M 4096
/system 154M 154M 0K 4096
/data 64M 57M 6M 4096
/cache 64M 1M 62M 4096
下面是/data/app目录的示例视图:
% adb shell ls -l /data/app
-rw-r--r-- system system 19949 2011-10-12 17:09 CubeLiveWallpapers.apk
-rw-r--r-- system system 27670 2011-10-12 17:09 GestureBuilder.apk
-rw-r--r-- system system 34341 2011-10-12 17:09 SoftKeyboard.apk
-rw-r--r-- system system 20151 2011-10-12 17:09 WidgetPreview.apk
我删除了多余的APK文件。似乎每次安装你都会得到一个新的APK文件。只需删除额外的APK文件。
例如,
adb shell rm /data/app/com.brooklynmarathon.calendarapi2-1.apk
谢谢你提出这个问题。我有一些额外的见解,可能会帮助一些开发人员。
我正在设备(不是模拟器)上调试我的应用程序。设备上有21 MB的空闲/数据(正如“df”在做“adb shell”时所显示的那样),我的应用程序只有5 MB。然而,我确实发现,如果我删除设备上的其他应用程序(没有重新启动手机或重新启动adbd), INSTALL_FAILED_INSUFFICIENT_STORAGE会消失一段时间,然后回来。
因此,似乎调试我的5 MB应用程序需要更多的20 MB的空间在/data中,此外,每次我调试我的应用程序都会泄露一些东西。
所以我做了“adb shell”,并列出了整个/data目录
cd /data
ls -a -l -R
我查看了5000行的输出,看看所有的空间都去了哪里。
我在设备的/data/klog目录中发现了大量浪费的空间,这些空间是几个月前调试会话的旧日志文件。
这些不是我的日志文件:它们是由Android基础设施的某些部分创建的。
我删除了它们,并立即保存了58mb,这在设置应用程序中没有归属于任何特定的应用程序。我的设备很小,所以58mb非常重要(约40%)。
到目前为止,在多次运行之后,我还没有再次得到INSTALL_FAILED_INSUFFICIENT_STORAGE。让我们希望这是真正的问题,尽管OP表明他的设备有足够的空间(但没有说有多少)。
希望你们中的一些人能够通过定期删除/data/klog/*来逃避INSTALL_FAILED_INSUFFICIENT_STORAGE。
或者,如果确实存在一些(隐藏的)空间问题,您至少可以在/data中执行ls -a -l -R来查看所有空间的去向。
以下方法会有所帮助:
打开设备的外壳
亚行壳
导航到第一次复制传入APK的临时目录
cd /数据/地方/ tmp
列出可用的文件并根据需要删除
Rm * //使用风险自负,最好先列出文件
到目前为止,这对我来说在实际设备上是可靠的。
编辑:事实证明,这个解决方案不像上面的解决方案那么可靠。
我尝试了很多方法。没有什么真的有用。最后我找到了一个叫SD Maid的应用程序。帮助。
该公司表示,该功能在非root设备上受到限制。我的工作是根深蒂固的,所以很高兴看到人们在这些情况下是有效的,如果它对我有效只是一个侥幸(无论如何这是一个不可预测的问题)。
注意:我和这个应用程序没有任何关系,只是通过搜索找到的。
回复这个话题的第一篇文章…
症状:某些应用程序不安装,说没有空间
实际上,内部和外部存储都有足够的空闲空间!!
解决方法:默认关闭外部安装。
默认设置外部安装:
adb shell pm set-install-location 2
使安装不可能在许多应用程序不能安装外部(如adblock +或左右)
那么答案是
adb shell pm set-install-location 0
Or
adb shell pm set-install-location 1
0: auto (if one is full - or irrelevant !!! - it select the other)
1: internal
2: external
这只是一个临时的解决方案,而不是真正的解决方案。
在我遇到这种情况后,我对目前的反应不满意,我去工作了
试图从AOSP源代码中找出答案。我找到了一个真正的解决方案。
解释
首先,简单介绍一下Android安装和更新的背景知识
第一次安装应用程序:
APK文件保存为
丹共/数据/应用/ < full.package.name > -1. (1. apk)
应用程序何时更新:
更新后的APK文件保存为:
丹共/数据/应用/ < full.package.name > -2. (2. apk)
第一个版本(1.apk)被删除。
在我们的下一次更新(s):
新的APK保存为(1.apk),删除(2.apk)(永远重复)。
我们大多数人遇到的问题发生在应用程序更新时,但删除旧的APK失败。这本身不会导致更新失败,但它会导致/data/app中有两个APK文件。
下次你尝试更新应用程序时,系统无法移动它的临时文件,因为(1.apk)和(2.apk)都不是空的。由于file# renameTo(File)不会抛出异常,而是返回一个布尔PackageManager,因此它没有任何方法告诉它为什么返回INSTALL_FAILED_INSUFFICIENT_STORAGE,即使失败与空闲空间无关。
解决方案
Run:
adb shell "pm uninstall <full.packge.name>"
adb shell "rm -rf /data/app/<full.package.name>-*"
OR
卸载应用程序
使用你最喜欢的方法删除这两个:
/data/app/<full.package.name>-1.apk
/data/app/<full.package.name>-2.apk
确保没有其他东西以类似的方式阻碍以后的安装。在我的情况下,我有一个/data/app-lib/<full.package.name>-1目录徘徊!在这种情况下,安装到SD卡以及随后移动到内部内存都是有效的。(创建/data/app-lib/<full.package.name>不带-1结尾)
为什么其他“解决方案”有效
安装到外部存储的代码有很大不同,但没有相同的问题
卸载app只会删除/data/app中APK文件的一个版本。这就是为什么你可以重新安装一次,但不能更新它。
当出现此错误时,模拟器中的空闲空间数量并不真正相关
在我的情况下,失败是由com.android.providers.media应用程序引起的。我在x86 android模拟器上遇到了这个问题。我做了什么:
$ adb shell df
Filesystem Size Used Free Blksize
...
/data 224M 209M 14M 4096
....
/data上的可用空间过低
$ adb shell du /data
...
409870 /data/data/com.android.providers.media
...
几乎所有的消费都来自于一个应用!它是系统应用程序,所以我认为最好不要删除它。相反,我清理了应用程序数据。
$ adb shell pm clear com.android.providers.media
Success
$ adb shell df
Filesystem Size Used Free Blksize
...
/data 224M 8M 215M 4096
...
磁盘已被清除,应用程序安装成功。