- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我已经搜索过答案,但找不到。我在 IntentService 中对纬度和纬度进行反向地理编码,然后当我尝试 ResultReceiver.send 时它会抛出 nullpointerexception。我调试了参数,它们包含地址和结果代码,就像它们应该的那样。我搜索了所有未初始化的对象,但找不到。谁能告诉我发生了什么事?
这是对纬度和经度进行反向地理编码的方法。
@Override
public void onHandleIntent(Intent intent) {
// TODO Auto-generated method stub
Geocoder geocoder = new Geocoder(this, Locale.getDefault());
String errorMessage = "";
// Get the location passed to this service through an extra.
Location location = intent.getParcelableExtra(
Constants.LOCATION_DATA_EXTRA);
List<Address> addresses = null;
try {
addresses = geocoder.getFromLocation(
location.getLatitude(),
location.getLongitude(),
// In this sample, get just one addresse.
1);
} catch (IOException ioException) {
// Catch network or other I/O problems.
errorMessage = getString(R.string.service_not_available);
Log.e(TAG, errorMessage, ioException);
} catch (IllegalArgumentException illegalArgumentException) {
// Catch invalid latitude or longitude values.
errorMessage = getString(R.string.invalid_lat_lon);
Log.e(TAG, errorMessage + ". " +
"Latitude = " + location.getLatitude() +
", Longitude = " +
location.getLongitude(), illegalArgumentException);
}
// Handle case where no address was found.
if (addresses == null || addresses.size() == 0) {
if (errorMessage.isEmpty()) {
errorMessage = getString(R.string.no_address_found);
Log.e(TAG, errorMessage);
}
deliverResultToReceiver(Constants.FAILURE_RESULT, errorMessage);
} else if (!"".equals(addresses) || null != addresses || addresses.size() > 0) {
Address address = addresses.get(0);
ArrayList<String> addressFragments = new ArrayList<String>();
// Fetch the address lines using getAddressLine,
// join them, and send them to the thread.
for(int i = 0; i < address.getMaxAddressLineIndex(); i++) {
addressFragments.add(address.getAddressLine(i));
}
//Log.i(TAG, getString(R.string.no_address_found));
if (!TextUtils.isEmpty(String.valueOf(addressFragments)))
//this is the line number 95 mentioned in the logcat
deliverResultToReceiver(Constants.SUCCESS_RESULT, TextUtils.join(System.getProperty("line.separator"), addressFragments));
}
//GetAddressString(addresses);
//return st;
}
private void deliverResultToReceiver(int resultCode, String message) {
Bundle bundle = new Bundle();
try {
if (message != null || !"".equals(message))
bundle.putString(Constants.RESULT_DATA_KEY, message);
//this is line number 113 mentioned in the logcat
mReceiver.send(resultCode, bundle);
} catch (NullPointerException npe) {
// TODO Auto-generated catch block
npe.printStackTrace();
}
}
这是日志
02-26 16:03:58.601: I/SELinux(7548): Function: selinux_android_load_priority [0], There is no sepolicy file.
02-26 16:03:58.601: I/SELinux(7548):
02-26 16:03:58.601: I/SELinux(7548): Function: selinux_android_load_priority [1], There is no sepolicy version file.
02-26 16:03:58.601: I/SELinux(7548):
02-26 16:03:58.601: I/SELinux(7548): Function: selinux_android_load_priority , priority version is VE=SEPF_SM-G800H_4.4.2_0018
02-26 16:03:58.601: I/SELinux(7548):
02-26 16:03:58.601: I/SELinux(7548):
02-26 16:03:58.601: I/SELinux(7548): selinux_android_seapp_context_reload: seapp_contexts file is loaded from /seapp_contexts
02-26 16:03:58.601: E/SELinux(7548): [DEBUG] seapp_context_lookup: seinfoCategory = default
02-26 16:03:58.601: E/dalvikvm(7548): >>>>> Normal User
02-26 16:03:58.601: E/dalvikvm(7548): >>>>> com.mypackage [ userId:0 | appId:10201 ]
02-26 16:03:58.621: E/SELinux(7548): [DEBUG] seapp_context_lookup: seinfoCategory = default
02-26 16:03:58.621: D/dalvikvm(7548): Late-enabling CheckJNI
02-26 16:03:58.671: D/TimaKeyStoreProvider(7548): in addTimaSignatureService
02-26 16:03:58.681: D/TimaKeyStoreProvider(7548): Cannot add TimaSignature Service, License check Failed
02-26 16:03:58.681: D/ActivityThread(7548): Added TimaKesytore provider
02-26 16:03:58.751: W/ActivityThread(7548): Application com.mypackage can be debugged on port 8100...
02-26 16:03:58.941: E/MoreInfoHPW_ViewGroup(7548): Parent view is not a TextView
02-26 16:03:59.001: I/x(7548): Making Creator dynamically
02-26 16:03:59.041: I/Google Maps Android API(7548): Google Play services client version: 6587000
02-26 16:03:59.051: I/Google Maps Android API(7548): Google Play services package version: 6776036
02-26 16:03:59.941: I/dalvikvm(7548): Could not find method android.content.pm.PackageManager.getPackageInstaller, referenced from method com.google.android.gms.common.ew.c
02-26 16:03:59.941: W/dalvikvm(7548): VFY: unable to resolve virtual method 441: Landroid/content/pm/PackageManager;.getPackageInstaller ()Landroid/content/pm/PackageInstaller;
02-26 16:03:59.941: D/dalvikvm(7548): VFY: replacing opcode 0x6e at 0x000f
02-26 16:03:59.981: W/ActivityThread(7548): ClassLoader.loadClass: The class loader returned by Thread.getContextClassLoader() may fail for processes that host multiple
applications. You should explicitly specify a context class loader. For example: Thread.setContextClassLoader(getClass().getClassLoader());
02-26 16:04:00.021: D/AbsListView(7548): Get MotionRecognitionManager
02-26 16:04:00.081: I/System.out(7548): Thread-618(HTTPLog):isShipBuild true
02-26 16:04:00.081: I/System.out(7548): Thread-618(HTTPLog):SmartBonding Enabling is false, SHIP_BUILD is true, log to file is false, DBG is false
02-26 16:04:00.221: I/Adreno-EGL(7548): <qeglDrvAPI_eglInitialize:410>: EGL 1.4 QUALCOMM build: ()
02-26 16:04:00.221: I/Adreno-EGL(7548): OpenGL ES Shader Compiler Version: E031.24.00.08
02-26 16:04:00.221: I/Adreno-EGL(7548): Build Date: 03/21/14 Fri
02-26 16:04:00.221: I/Adreno-EGL(7548): Local Branch: AU200+patches_03212014
02-26 16:04:00.221: I/Adreno-EGL(7548): Remote Branch:
02-26 16:04:00.221: I/Adreno-EGL(7548): Local Patches:
02-26 16:04:00.221: I/Adreno-EGL(7548): Reconstruct Branch:
02-26 16:04:00.251: I/HWUI(7548): EGLImpl-HWUI Protected EGL context created
02-26 16:04:00.261: D/OpenGLRenderer(7548): Enabling debug mode 0
02-26 16:04:01.301: D/dalvikvm(7548): GC_FOR_ALLOC freed 17677K, 55% free 16268K/35592K, paused 55ms, total 55ms
02-26 16:04:03.161: D/dalvikvm(7548): GC_FOR_ALLOC freed 7882K, 54% free 16547K/35592K, paused 48ms, total 48ms
02-26 16:04:08.201: W/System.err(7548): java.lang.NullPointerException
02-26 16:04:08.201: W/System.err(7548): at com.mypackage.FetchAddressIntentService.deliverResultToReceiver(FetchAddressIntentService.java:113)
02-26 16:04:08.201: W/System.err(7548): at com.mypackage.FetchAddressIntentService.onHandleIntent(FetchAddressIntentService.java:95)
02-26 16:04:08.201: W/System.err(7548): at android.app.IntentService$ServiceHandler.handleMessage(IntentService.java:65)
02-26 16:04:08.201: W/System.err(7548): at android.os.Handler.dispatchMessage(Handler.java:102)
02-26 16:04:08.201: W/System.err(7548): at android.os.Looper.loop(Looper.java:146)
02-26 16:04:08.211: W/System.err(7548): at android.os.HandlerThread.run(HandlerThread.java:61)
最佳答案
您得到空指针异常的原因是因为您创建的 ResultReceiver 尚未实例化。关于 https://developer.android.com/training/location/display-address.html 的 Google 培训似乎没有专门处理这个问题,但尽管如此,在请求“FetchAddressIntentService”的应用程序的 MainActivity 中,您可以实例化 ResultReceiver。
主 Activity .java
protected void startIntentService() {
Intent intent = new Intent(this, AddressIntentService.class);
mResultReceiver = new AddressResultReceiver(new Handler()); //instantiate here
intent.putExtra(RECEIVER, mResultReceiver);
intent.putExtra(LOCATION_DATA_EXTRA, mLastLocation);
startService(intent);
}
然后在您的 FetchAddressIntentService.java 中,您将从意向包中提取 mResultReceiver 项,如下所示:
@Override
protected void onHandleIntent(Intent intent) {
Bundle parameters = intent.getExtras();
mReceiver = parameters.getParcelable(RECEIVER); }
重新运行您的代码,空指针异常在我们实例化时消失。
关于java - ResultReceiver.send 抛出 nullpointerexception,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28754760/
我正在将我的模板代码移植到 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 的帮助下录制视频.我程序上的所有代码都与此页面相同。 我在 之外定义了权限标签。 当应
我是一名优秀的程序员,十分优秀!