IllegalArgumentException由requestLocationUpdate()引发

我们最近在android API级别14和15上testing了我们的应用程序。我们开始开发针对最小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(); } 

根据文档 , if provider or listener is null则会引发IAE。 但是我logging了提供者和监听者。 (后者通过toString()),它们不是null。

来自这个问题,我发现一个公开的问题 。 但是我想知道人们对冰淇淋三明治更有信心,要求用户的坐标。
我所知道的教程使用了上述相同的方法。

Solutions Collecting From Web of "IllegalArgumentException由requestLocationUpdate()引发"

我认为这可能是目前Android模拟器的一个问题。

请参阅http://code.google.com/p/android/issues/detail?id=21237

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

在你的代码中使用这个LocationManager.NETWORK_PROVIDER当你testing,确保你正在使用的networking如WIFI可用,或者你的设备中插入了SIM卡,networking可用。

您也可以使用LocationManager.GPS_PROVIDER进行testing,但在使用GPS之前请确保设备处于ON状态