requestLocationUpdate() 抛出 IllegalArgumentException。

9
我们最近对我们的应用程序进行了Android API级别14和15的测试。我们开始的开发目标是面向最小的SKD版本8,并排除平板电脑(3.x)。在2.x上,一切都运行良好,但在4.x的安卓设备上运行应用程序时,在获取用户位置时会崩溃。
FATAL EXCEPTION: main
java.lang.RuntimeException: Unable to create service  java.lang.IllegalArgumentException: provider=network  
at android.app.ActivityThread.handleCreateService(ActivityThread.java:2263)  
at android.app.ActivityThread.access$1600(ActivityThread.java:123)  
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1201)  
at android.os.Handler.dispatchMessage(Handler.java:99)  
at android.os.Looper.loop(Looper.java:137)  
at android.app.ActivityThread.main(ActivityThread.java:4424)  
at java.lang.reflect.Method.invokeNative(Native Method)  
at java.lang.reflect.Method.invoke(Method.java:511)  
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)  
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)  
at dalvik.system.NativeStart.main(Native Method)  

Caused by: java.lang.IllegalArgumentException: provider=network  
at android.os.Parcel.readException(Parcel.java:1331)  
at android.os.Parcel.readException(Parcel.java:1281)  
at android.location.ILocationManager$Stub$Proxy.requestLocationUpdates(ILocationManager.java:646)  
at android.location.LocationManager._requestLocationUpdates(LocationManager.java:582)   
at android.location.LocationManager.requestLocationUpdates(LocationManager.java:446)  
at package.name.LocationGetter.onCreate(LocationGetter.java:63)  
at android.app.ActivityThread.handleCreateService(ActivityThread.java:2253)  
...

来源:

public void onCreate() {
  locationManager = (LocationManager) this.getSystemService(Context.LOCATION_SERVICE);
  locationManager.requestLocationUpdates(LocationManager.NETWORK_PROVIDER, 300000, 500, locationListener);
  super.onCreate();
 }

根据文档,如果provider或listener为空,则会抛出IAE异常。然而,我记录了provider和listener(后者通过toString()),它们不为空。
这个问题中得知,有一个已公开的问题。但是我想知道更熟悉冰淇淋三明治的人如何请求用户的坐标。
我知道的教程使用了上述相同的方法。

1
我认为你应该将 super() 放在 onCreate() 的第一个调用位置... 我会尝试这样做 :) - Ovidiu Latcu
是的,总是在纠结把它放在哪里。无论如何 - 问题仍然存在。 - nuala
遇到了同样的问题。我想知道这是模拟器的问题还是真正的ICS设备问题。 - Michał Klimczak
2个回答

4

是的,谢谢指出。另外评论#5提供了一个明显的解决方法:捕获异常并暂时接受它。gnah <.< http://code.google.com/p/android/issues/detail?id=21237#c5 - nuala

2
locationManager.requestLocationUpdates(LocationManager.NETWORK_PROVIDER, 300000, 500, locationListener);

在您的代码中使用LocationManager.NETWORK_PROVIDER,在测试时确保您使用的网络(如WIFI)可用,或者您已在设备中插入了SIM卡并且网络可用。
您也可以使用LocationManager.GPS_PROVIDER进行测试,但在使用之前请确保设备的GPS已打开。

是的,WiFi可用。(否则我就不能发布这个:P)。 - nuala

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接