- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我的生产应用最近开始遇到这种崩溃。
完整的 StackTrace 如下:
Fatal Exception: java.lang.RuntimeException: Unable to start receiver com.google.android.datatransport.runtime.scheduling.jobscheduling.AlarmManagerSchedulerBroadcastReceiver: java.lang.NullPointerException: Attempt to invoke virtual method 'java.lang.String android.net.Uri.getQueryParameter(java.lang.String)' on a null object reference
at android.app.ActivityThread.handleReceiver(ActivityThread.java:2735)
at android.app.ActivityThread.-wrap14(ActivityThread.java)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1424)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:148)
at android.app.ActivityThread.main(ActivityThread.java:5421)
at java.lang.reflect.Method.invoke(Method.java)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)
Caused by java.lang.NullPointerException: Attempt to invoke virtual method 'java.lang.String android.net.Uri.getQueryParameter(java.lang.String)' on a null object reference
at com.google.android.datatransport.runtime.scheduling.jobscheduling.AlarmManagerSchedulerBroadcastReceiver.onReceive(AlarmManagerSchedulerBroadcastReceiver.java:31)
at android.app.ActivityThread.handleReceiver(ActivityThread.java:2728)
at android.app.ActivityThread.-wrap14(ActivityThread.java)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1424)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:148)
at android.app.ActivityThread.main(ActivityThread.java:5421)
at java.lang.reflect.Method.invoke(Method.java)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)
我可以找到 AlarmManagerSchedulerBroadcastReceiver
的代码,如下所示:
package com.google.android.datatransport.runtime.scheduling.jobscheduling;
import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.util.Base64;
import com.google.android.datatransport.runtime.TransportContext;
import com.google.android.datatransport.runtime.TransportRuntime;
import com.google.android.datatransport.runtime.TransportContext.Builder;
import com.google.android.datatransport.runtime.util.PriorityMapping;
public class AlarmManagerSchedulerBroadcastReceiver extends BroadcastReceiver {
public AlarmManagerSchedulerBroadcastReceiver() {
}
public void onReceive(Context context, Intent intent) {
String backendName = intent.getData().getQueryParameter("backendName");
String extras = intent.getData().getQueryParameter("extras");
int priority = Integer.valueOf(intent.getData().getQueryParameter("priority"));
int attemptNumber = intent.getExtras().getInt("attemptNumber");
TransportRuntime.initialize(context);
Builder transportContext = TransportContext.builder().setBackendName(backendName).setPriority(PriorityMapping.valueOf(priority));
if (extras != null) {
transportContext.setExtras(Base64.decode(extras, 0));
}
TransportRuntime.getInstance().getUploader().upload(transportContext.build(), attemptNumber, AlarmManagerSchedulerBroadcastReceiver$$Lambda$1.lambdaFactory$());
}
我搜索了整个代码库范围,发现 This BroadcastReceiver 正在使用:
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.google.android.datatransport.runtime" >
<uses-sdk
android:minSdkVersion="14"
android:targetSdkVersion="29" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<!-- Although the *SdkVersion is captured in gradle build files, this is required for non gradle builds -->
<!-- <uses-sdk android:minSdkVersion="14"/> -->
<application>
<service
android:name="com.google.android.datatransport.runtime.scheduling.jobscheduling.JobInfoSchedulerService"
android:exported="false"
android:permission="android.permission.BIND_JOB_SERVICE" >
</service>
<receiver
android:name="com.google.android.datatransport.runtime.scheduling.jobscheduling.AlarmManagerSchedulerBroadcastReceiver"
android:exported="false" />
<service
android:name="com.google.android.datatransport.runtime.backends.TransportBackendDiscovery"
android:exported="false" />
</application>
我发现 AlarmManagerScheduler
触发了这个:
package com.google.android.datatransport.runtime.scheduling.jobscheduling;
public class AlarmManagerScheduler implements WorkScheduler {
private static final String LOG_TAG = "AlarmManagerScheduler";
static final String ATTEMPT_NUMBER = "attemptNumber";
static final String BACKEND_NAME = "backendName";
static final String EVENT_PRIORITY = "priority";
static final String EXTRAS = "extras";
private final Context context;
private final EventStore eventStore;
private AlarmManager alarmManager;
private final SchedulerConfig config;
private final Clock clock;
public AlarmManagerScheduler(Context applicationContext, EventStore eventStore, Clock clock, SchedulerConfig config) {
this(applicationContext, eventStore, (AlarmManager)applicationContext.getSystemService("alarm"), clock, config);
}
@VisibleForTesting
AlarmManagerScheduler(Context applicationContext, EventStore eventStore, AlarmManager alarmManager, Clock clock, SchedulerConfig config) {
this.context = applicationContext;
this.eventStore = eventStore;
this.alarmManager = alarmManager;
this.clock = clock;
this.config = config;
}
@VisibleForTesting
boolean isJobServiceOn(Intent intent) {
return PendingIntent.getBroadcast(this.context, 0, intent, 536870912) != null;
}
public void schedule(TransportContext transportContext, int attemptNumber) {
Builder intentDataBuilder = new Builder();
intentDataBuilder.appendQueryParameter("backendName", transportContext.getBackendName());
intentDataBuilder.appendQueryParameter("priority", String.valueOf(PriorityMapping.toInt(transportContext.getPriority())));
if (transportContext.getExtras() != null) {
intentDataBuilder.appendQueryParameter("extras", Base64.encodeToString(transportContext.getExtras(), 0));
}
Intent intent = new Intent(this.context, AlarmManagerSchedulerBroadcastReceiver.class);
intent.setData(intentDataBuilder.build());
intent.putExtra("attemptNumber", attemptNumber);
if (this.isJobServiceOn(intent)) {
Logging.d("AlarmManagerScheduler", "Upload for context %s is already scheduled. Returning...", transportContext);
} else {
long backendTime = this.eventStore.getNextCallTime(transportContext);
long scheduleDelay = this.config.getScheduleDelay(transportContext.getPriority(), backendTime, attemptNumber);
Logging.d("AlarmManagerScheduler", "Scheduling upload for context %s in %dms(Backend next call timestamp %d). Attempt %d", new Object[]{transportContext, scheduleDelay, backendTime, attemptNumber});
PendingIntent pendingIntent = PendingIntent.getBroadcast(this.context, 0, intent, 0);
this.alarmManager.set(3, this.clock.getTime() + scheduleDelay, pendingIntent);
}
}
}
我不明白,为什么 intent.getData() 会变成 null?
有人可以帮我解决这个崩溃问题吗?
最佳答案
看起来 .getData()
正在返回 null,您应该查看要添加此数据的位置以及应用程序未发送它的原因。
您应该检查方法中的可空性:
public void onReceive(Context context, Intent intent) {
if(intent.getData() != null){
String backendName = intent.getData().getQueryParameter("backendName");
String extras = intent.getData().getQueryParameter("extras");
int priority =
Integer.valueOf(intent.getData().getQueryParameter("priority"));
int attemptNumber = intent.getExtras().getInt("attemptNumber");
TransportRuntime.initialize(context);
Builder transportContext = TransportContext.builder().setBackendName(backendName).setPriority(PriorityMapping.valueOf(priority));
if (extras != null) {
transportContext.setExtras(Base64.decode(extras, 0));
}
TransportRuntime.getInstance().getUploader().upload(transportContext.build(), attemptNumber, AlarmManagerSchedulerBroadcastReceiver$$Lambda$1.lambdaFactory$());
}
}
关于android - 无法启动接收器 AlarmManagerSchedulerBroadcastReceiver : Attempt to invoke method 'android.net.Uri.getQueryParameter()' on a null object,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/64567947/
媒体存在于外部服务器上,我想在我的 Actor 接收器上播放该媒体( Google's CastReferencePlayer 的修改版本)。接收器与该服务器持续通信(通过长轮询),并在需要播放某个媒
我想将我的 PyQt4 应用程序移植到 PyQt5,但遇到了一个微妙的问题。 有时我会检查自定义 QThread 对象 (worker) 是否仍然连接了一些特定的信号,我在 PyQt4 中已经这样做了
假设我们有 n 台设备,n 为偶数。每个设备都可以作为发射器 (T) 或接收器 (R)。对于每个设备 i,我们都给定了 2 个数字,Ti 和 Ri。 Ti 是设备用作发射器时的成本,Ri 是设备用作接
我想在 android 中创建 airplay,其中我的 android 设备将用作 airplay 服务器(接收器),而 iPhone 设备将用作接收器。我在我的应用程序中使用了 jmdns,它是
简单问题 - 我可以将单个 BroadcastReceiver 注册到多个 Intent 操作吗?这是我正在考虑的: 所以在 myRecei
假设我在 2 个应用程序(应用程序 A 和应用程序 B)的 list 中有以下接收器: 在每个应用程序中,我想创建一个 PendingIntent(如果不存在
我正在尝试向接收方应用程序的关闭事件添加逻辑,但每次发送方断开连接时,调试器都会关闭并且不会执行任何逻辑(例如发送一些 HttpRequest)。我的一段代码: this.context.addEve
我们正在使用flume,我需要将一些日志消息收集到rabbitmq 中。我找到了一个来源 implementation从rabbitmq读取消息,但我找不到可以将消息写入rabbit的接收器。所以我想
我遇到了一个远程异常: “这个远程代理没有 channel 接收器,这意味着服务器没有注册的服务器 channel 正在监听,或者这个应用程序没有合适的客户端 channel 来与服务器通信。” th
我是 WebRTC 的新手,并试图弄清楚如何在浏览器之外创建一个程序,该程序接收 WebRTC 音频流并将其输出到扬声器上。 是否有适用于 Java 或 C# 的 WebRTC 库? 该接收器将在 l
我正在创建一个简单的 Spring Boot 应用程序,我想接收发送到 AMQP(Rabbit)交换(来自另一个应用程序)的消息。 我收到一条错误消息,指出我要接收的队列不存在。当我看 http://
我将 EJB 3.0 与 JBoss AS 7.1.1 Final 一起使用。当我尝试将客户端连接到服务器时出现此错误: Aug 15, 2012 12:05:00 PM org.jboss.ejb.
我正在为 Google Cast SDK 使用 React Native 包装器,但无法从发送方向接收方发送消息。我能够转换媒体或暂停并恢复它。问题仅在于自定义消息。我的自定义消息监听器永远不会在接收
我正在开发自定义 Serilog 接收器,它继承自 PeriodicBatchingSink 并调用我的网络服务将数据写入数据库,使用类似于 Serilog.Sinks.Seq 的模式。使用此代码作为
我想为安卓手机开发一个定制的 FM radio 应用程序,里面有 FM 接收芯片。 通过研究,我发现 FM 接收器通常由 BroadComm 开发。 主要的安卓手机制造商——三星、HTC、索尼爱立信是
我的 android list 中有一个 Intent 接收器,但我想让用户有机会选择他/她是否希望应用程序在特定状态下自动启动。到目前为止,我一直在使用带有广播接收器的服务,但我真的很想删除这个服务
我正在做一个如果我们摇动手机就锁屏的应用程序,我已经写了屏幕关闭的代码,但现在的问题是我需要一个广播接收器来检查屏幕是关闭还是打开,我怎么能做吗? 最佳答案 如果您需要在特定时刻检查屏幕是否关闭或打开
我让 MySQL 在一页上生成具有相同操作和提交按钮的表单。表格的数量各不相同。它们在提交时都调用同一个 PHP 文件。另外,我有一个 PHP 文件,它在提交时收集数据。请参见下面的示例。 问题是当提
谁能给我一个例子,说明如何在 Activity 类中正确取消注册 LocalBroadcastManager 接收器? Android 开发人员培训建议这样做: @Override publ
有问题的代码: func tableView(tableView: UITableView, didSelectRowAtIndexPath indexPath: NSIndexPath) {
我是一名优秀的程序员,十分优秀!