我有一个服务的启动应用程序正常运行,但在pused作为系统应用程序后,它无法安装:F/FileObserver( 367): Unhandled exception in FileObserver com.android.server.pm.PackageManagerService$AppDirObserver@41130430
F/FileObserver( 367): java.lang.NullPointerException: name == null
F/FileObserver( 367): at java.io.File.(File.java:150)
F/FileObserver( 367): at java.io.File.(File.java:124)
F/FileObserver( 367): at com.android.server.pm.PackageManagerService.getDataPathForPackage(PackageManagerService.java:3579)
F/FileObserver( 367): at com.android.server.pm.PackageManagerService.scanPackageLI(PackageManagerService.java:3940)
F/FileObserver( 367): at com.android.server.pm.PackageManagerService.scanPackageLI(PackageManagerService.java:3382)
F/FileObserver( 367): at com.android.server.pm.PackageManagerService.access$1700(PackageManagerService.java:172)
F/FileObserver( 367): at com.android.server.pm.PackageManagerService$AppDirObserver.onEvent(PackageManagerService.java:5541)
F/FileObserver( 367): at android.os.FileObserver$ObserverThread.onEvent(FileObserver.java:125)
F/FileObserver( 367): at android.os.FileObserver$ObserverThread.observe(Native Method)
F/FileObserver( 367): at android.os.FileObserver$ObserverThread.run(FileObserver.java:88)
D/dalvikvm( 367): GC_FOR_ALLOC freed 1488K, 25% free 11974K/15816K, paused 56ms, total 57ms
字符串空指针发生了什么? !
以下是来自 PackageManagerService ( android4.2 )的相关Android源代码:private File getDataPathForPackage(String packageName, int userId) {
/*
* Until we fully support multiple users, return the directory we
* previously would have. The PackageManagerTests will need to be
* revised when this is changed back..
*/
if (userId == 0) {
return new File(mAppDataDir, packageName);
} else {
return new File(mUserAppDataDir.getAbsolutePath() + File.separator + userId
+ File.separator + packageName);
}
}
但我还是不知道。
UDPATE:
这就是清单中 标签的原因,去掉它,并解决问题。