- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我知道这个问题是重复的。但是我在这里找不到合适的解决方案。我正在开发一个 Android 时钟小部件,并且在我的 Nexus 4 和我兄弟的 hTC One X 设备上运行顺利。但在其他设备上,如 Galaxy SII、SIII 和 Nexus 10,应用程序会在配置 Activity 出现后崩溃,并显示由于 NPE 导致的 Force Stop 消息:
PendingIntent pendingIntent = PendingIntent.getActivity(context, 0, i, PendingIntent.FLAG_UPDATE_CURRENT);
这是包含该行的方法:
public void update(Context context, int nn){
final RemoteViews localRemoteViews = create(context);
prefsFile.getBoolean(String.valueOf(nn) + "app_onclick", true)) {
packageName = prefsFile.getString("packageName", "Not Available");
PackageManager packageManager = context.getPackageManager();
Intent i = new Intent(Intent.ACTION_MAIN, null);
i.addCategory(Intent.CATEGORY_LAUNCHER);
i = packageManager.getLaunchIntentForPackage(packageName);
PendingIntent pendingIntent = PendingIntent.getActivity(context, 0, i, PendingIntent.FLAG_UPDATE_CURRENT);
localRemoteViews.setOnClickPendingIntent(R.id.img, pendingIntent);
}
widgetManager.updateAppWidget(nn, localRemoteViews);
}
接收时:
public void onReceive(Context context, Intent n)
{
super.onReceive(context, n);
prefsFile = context.getSharedPreferences("MyPrefs", 0);
ComponentName localComponentName = new ComponentName(context.getPackageName(), getClass().getName());
widgetManager = AppWidgetManager.getInstance(context);
WidgetIds = widgetManager.getAppWidgetIds(localComponentName);
if ((paramIntent.getAction().equals("android.intent.action.BOOT_COMPLETED")) && (this.mAppWidgetIds.length > 0))
{
for (int n : this.WidgetIds) {
packageName = prefsFile.getString("packageName", "Not Available");
update(context, n);
}
}
}
list :
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.koshmen.clock.aimen"
android:versionCode="8"
android:versionName="1.3.4" >
<uses-sdk
android:minSdkVersion="11"
android:targetSdkVersion="19" />
<application
android:allowBackup="true"
android:icon="@drawable/ic_launcher"
android:label="@string/app_name"
android:theme="@style/Theme.AppCompat" >
<receiver
android:name="com.koshmen.clock.aimen.Yarab"
android:label="@string/app_name" >
<intent-filter>
<action android:name="android.appwidget.action.APPWIDGET_UPDATE" />
</intent-filter>
<intent-filter>
<action android:name="android.intent.action.BOOT_COMPLETED" />
</intent-filter>
<meta-data
android:name="android.appwidget.provider"
android:resource="@xml/widget_stuff" />
</receiver>
<activity
android:name="com.koshmen.clock.aimen.YarabConfig"
android:label="@string/app_name" >
<intent-filter>
<action android:name="android.appwidget.action.APPWIDGET_CONFIGURE" />
</intent-filter>
</activity>
</application>
这是我手机上安装的 LogCat 应用程序的 Logcat 结果,我无法在我的 PC 上使用它们,上下文来自 onReceive 方法,该方法使用 widgetID (n) 传递上下文。为什么应用程序在某些设备上运行而不在其他设备上运行?并给出 NPE 错误?
update method onReceive method
这是来自 Eclipse logCat 的最新日志:
05-24 01:47:56.863: D/dalvikvm(23665): JIT code cache reset in 0 ms (0 bytes 4/0)
05-24 01:47:56.863: D/dalvikvm(23665): GC_FOR_ALLOC freed 481K, 41% free 9988K/16904K, paused 38ms, total 38ms
05-24 01:47:56.983: D/dalvikvm(23665): GC_FOR_ALLOC freed 502K, 41% free 9998K/16936K, paused 41ms, total 41ms
05-24 01:47:57.068: D/dalvikvm(23665): GC_FOR_ALLOC freed 225K, 41% free 10003K/16936K, paused 29ms, total 29ms
05-24 01:47:57.068: I/dalvikvm-heap(23665): Grow heap (frag case) to 17.453MB for 1468960-byte allocation
05-24 01:47:57.088: D/dalvikvm(23665): GC_FOR_ALLOC freed 0K, 38% free 11438K/18372K, paused 20ms, total 20ms
05-24 01:47:57.153: D/mali_winsys(23665): new_window_surface returns 0x3000
05-24 01:47:57.183: D/OpenGLRenderer(23665): Enabling debug mode 0
05-24 01:47:59.323: D/dalvikvm(23665): GC_FOR_ALLOC freed 11K, 38% free 11519K/18372K, paused 29ms, total 29ms
05-24 01:48:07.733: D/dalvikvm(23665): GC_FOR_ALLOC freed 45K, 38% free 11531K/18392K, paused 40ms, total 40ms
05-24 01:48:07.733: I/dalvikvm-heap(23665): Grow heap (frag case) to 17.721MB for 186640-byte allocation
05-24 01:48:07.768: D/dalvikvm(23665): GC_FOR_ALLOC freed <1K, 37% free 11713K/18576K, paused 36ms, total 36ms
05-24 01:48:07.808: D/dalvikvm(23665): GC_FOR_ALLOC freed <1K, 37% free 11713K/18576K, paused 38ms, total 38ms
05-24 01:48:07.808: I/dalvikvm-heap(23665): Grow heap (frag case) to 17.899MB for 186640-byte allocation
05-24 01:48:07.848: D/dalvikvm(23665): GC_FOR_ALLOC freed 0K, 37% free 11895K/18760K, paused 39ms, total 39ms
05-24 01:48:07.893: D/dalvikvm(23665): GC_FOR_ALLOC freed 0K, 37% free 12078K/18944K, paused 44ms, total 44ms
05-24 01:48:07.958: D/dalvikvm(23665): GC_FOR_ALLOC freed 1K, 36% free 12263K/19128K, paused 42ms, total 42ms
05-24 01:48:07.988: D/dalvikvm(23665): GC_FOR_ALLOC freed <1K, 36% free 12445K/19312K, paused 23ms, total 23ms
05-24 01:48:08.018: D/dalvikvm(23665): GC_FOR_ALLOC freed <1K, 35% free 12810K/19680K, paused 26ms, total 26ms
05-24 01:48:08.028: D/AndroidRuntime(23665): Shutting down VM
05-24 01:48:08.028: W/dalvikvm(23665): threadid=1: thread exiting with uncaught exception (group=0x415ebba8)
05-24 01:48:08.028: E/AndroidRuntime(23665): FATAL EXCEPTION: main
05-24 01:48:08.028: E/AndroidRuntime(23665): Process: com.koshmen.clock.aimen, PID: 23665
05-24 01:48:08.028: E/AndroidRuntime(23665): java.lang.RuntimeException: Unable to start receiver com.koshmen.clock.aimen.Yarab: java.lang.NullPointerException
05-24 01:48:08.028: E/AndroidRuntime(23665): at android.app.ActivityThread.handleReceiver(ActivityThread.java:2426)
05-24 01:48:08.028: E/AndroidRuntime(23665): at de.robv.android.xposed.XposedBridge.invokeOriginalMethodNative(Native Method)
05-24 01:48:08.028: E/AndroidRuntime(23665): at de.robv.android.xposed.XposedBridge.handleHookedMethod(XposedBridge.java:631)
05-24 01:48:08.028: E/AndroidRuntime(23665): at android.app.ActivityThread.handleReceiver(Native Method)
05-24 01:48:08.028: E/AndroidRuntime(23665): at android.app.ActivityThread.access$1700(ActivityThread.java:135)
05-24 01:48:08.028: E/AndroidRuntime(23665): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1272)
05-24 01:48:08.028: E/AndroidRuntime(23665): at android.os.Handler.dispatchMessage(Handler.java:102)
05-24 01:48:08.028: E/AndroidRuntime(23665): at android.os.Looper.loop(Looper.java:136)
05-24 01:48:08.028: E/AndroidRuntime(23665): at android.app.ActivityThread.main(ActivityThread.java:5017)
05-24 01:48:08.028: E/AndroidRuntime(23665): at java.lang.reflect.Method.invokeNative(Native Method)
05-24 01:48:08.028: E/AndroidRuntime(23665): at java.lang.reflect.Method.invoke(Method.java:515)
05-24 01:48:08.028: E/AndroidRuntime(23665): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779)
05-24 01:48:08.028: E/AndroidRuntime(23665): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
05-24 01:48:08.028: E/AndroidRuntime(23665): at de.robv.android.xposed.XposedBridge.main(XposedBridge.java:132)
05-24 01:48:08.028: E/AndroidRuntime(23665): at dalvik.system.NativeStart.main(Native Method)
05-24 01:48:08.028: E/AndroidRuntime(23665): Caused by: java.lang.NullPointerException
05-24 01:48:08.028: E/AndroidRuntime(23665): at android.app.PendingIntent.getActivity(PendingIntent.java:261)
05-24 01:48:08.028: E/AndroidRuntime(23665): at android.app.PendingIntent.getActivity(PendingIntent.java:224)
05-24 01:48:08.028: E/AndroidRuntime(23665): at com.koshmen.clock.aimen.Yarab.update(Yarab.java:251)
05-24 01:48:08.028: E/AndroidRuntime(23665): at com.koshmen.clock.aimen.Yarab.onReceive(Yarab.java:226)
05-24 01:48:08.028: E/AndroidRuntime(23665): at android.app.ActivityThread.handleReceiver(ActivityThread.java:2419)
05-24 01:48:08.028: E/AndroidRuntime(23665): ... 14 more
05-24 01:48:09.783: I/Process(23665): Sending signal. PID: 23665 SIG: 9
最佳答案
NullPointerException
来自 PendingIntent.getActivity()
方法,它发生在尝试调用 Intent
参数的方法时你通过这个电话:
PendingIntent pendingIntent = PendingIntent.getActivity(context, 0, i,
PendingIntent.FLAG_UPDATE_CURRENT);
变量i
为null
。
在您的代码中,您这样做:
i = packageManager.getLaunchIntentForPackage(packageName);
PendingIntent pendingIntent = PendingIntent.getActivity(context, 0, i,
PendingIntent.FLAG_UPDATE_CURRENT);
因为调用 PackageManager.getLaunchIntentForPackage()
可能会返回 null
,所以您需要添加代码来检查该条件。
关于android - 运行时异常 : Unable to start receiver "package name" : NullPointerException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23837711/
我正在将我的模板代码移植到 XTend。在某些时候,我在测试用例中有这种类型的条件处理: @Test def xtendIfTest() { val obj = new FD if (
我是新来的 kotlin , 当我开始 Null Safety 时,我对下面的情况感到困惑. There's some data inconsistency with regard to initia
我的应用程序一直在各种Android版本中保持良好状态。我有用户在Android 4.3、5.0、5.1和6.0上正常运行。但是,具有S7 Edge的用户刚刚更新了Android 7.0,将文本粘贴到
我使用的是最新版本的 LWUIT (1.5)。我在资源编辑器中设计了我的表单,然后将代码生成到 netbeans。问题是如果我想访问除表单之外的任何对象,我会收到此错误: java.lang.Null
更新: 我在 Fedora 21 上运行它。 SonarQube - 5.0。 SonarQube Runner - 2.4 更新 2:Findbugs v3.1,Java 插件 v2.8 更新3:
RecupData 我的类仅在 web 中返回 NullPointerException。我连接到 pgsql db 8.3.7 - 该脚本在“控制台”syso 中运行良好 - 但引发了测试 Web
我在 mac 上使用 Processing 2.08。我正在尝试使用文档中给出的 createShape 函数创建 PShape。 PShape s; void setup(){ size(500
我在 mac 上使用 Processing 2.08。我正在尝试使用文档中给出的 createShape 函数创建 PShape。 PShape s; void setup(){ size(500
每次运行此 jsp 时,都会收到以下错误异常: org.apache.jasper.JasperException: java.lang.NullPointerException root cause
Kotlin 在编译时有一个出色的 null 检查,使用分离到“可空?”和“不可为空”的对象。它有一个 KAnnotator 来帮助确定来自 Java 的对象是否可以为空。但是,如果 not-null
我有一个布局将显示一个TextView,用于显示一个滴答时间。我遵循了此链接中的代码 How to Display current time that changes dynamically for
Elasticsearch 1.4.1版(“lucene_version”:“4.10.2”) 我有一个像这样的文件: $ curl 'http://localhost:9200/blog/artic
这是我从另一个类调用函数的方法Selenium 设置已定义。 public void Transfer() throws Exception { System.out.println("\nTrans
我试图在主类中使用我在此类中创建的函数,但它崩溃并显示“警告:无法在根 0 处打开/创建首选项根节点 Software\JavaSoft\Prefsx80000002。 Windows RegCrea
这个问题已经有答案了: What is a NullPointerException, and how do I fix it? (12 个回答) 已关闭 3 年前。 我有一个 Java 代码,它将
我声明了两张牌: Card card1 = new Card('3', Card.Suit.clubs); Card card2 = new Card('T', Card.Suit.diamonds)
我编写了一段代码来解码 Base64 图像并在 javafx 中表示该图像。在我的 url base64 代码中不断变化。这就是我在 javafx 代码中使用任务的原因。但我收到错误:java.lan
我正在尝试使用 arrayList 的 arrayList 在 Java 中实现图形。 每当调用 addEdge 函数时,我都会收到 NullPointerException 。我似乎无法弄清楚为什么
我是 Java/android 的新手,所以很多这些术语都是外国的,但我愿意学习。我不打算详细介绍该应用程序,因为我认为它不相关。我目前的问题是,我使用了博客中的教程和代码 fragment ,并使我
我正在开发一个 Android 应用程序来在 Android developer guide 的帮助下录制视频.我程序上的所有代码都与此页面相同。 我在 之外定义了权限标签。 当应
我是一名优秀的程序员,十分优秀!