Android GPS检查崩溃?

Android GPS检查崩溃?,android,crash,gps,Android,Crash,Gps,从昨天开始到处搜索,找不到有此问题的人: 我创建了一个GPS检查功能,它只返回true或false,指示GPS是否处于开启状态。在android 2.2和4.1中,在模拟器和运行4.1的手机上都可以很好地工作 功能如下: private Boolean checkGPSEnabled(){ try{ String provider = Settings.Secure.getString(getContentResolver(), Settings.

从昨天开始到处搜索,找不到有此问题的人:

我创建了一个GPS检查功能,它只返回true或false,指示GPS是否处于开启状态。在android 2.2和4.1中,在模拟器和运行4.1的手机上都可以很好地工作

功能如下:

    private Boolean checkGPSEnabled(){
        try{
            String provider = Settings.Secure.getString(getContentResolver(), Settings.Secure.LOCATION_PROVIDERS_ALLOWED);
            if(provider.toLowerCase().contains("gps")){
                return true;
            }
        }
        catch(IllegalArgumentException e){
            return true;
        }

        return false;
    }
问题是,当在Android仿真器上执行此检查时启用GPS时,仿真器会彻底崩溃

以下是发生错误时在LogCat中打印的内容:

10-12 15:23:45.593: W/dalvikvm(899): threadid=1: thread exiting with uncaught exception (group=0x40a13300)
10-12 15:23:45.644: E/AndroidRuntime(899): FATAL EXCEPTION: main
10-12 15:23:45.644: E/AndroidRuntime(899): java.lang.IllegalStateException: Could not execute method of the activity
10-12 15:23:45.644: E/AndroidRuntime(899):  at android.view.View$1.onClick(View.java:3591)
10-12 15:23:45.644: E/AndroidRuntime(899):  at android.view.View.performClick(View.java:4084)
10-12 15:23:45.644: E/AndroidRuntime(899):  at android.view.View$PerformClick.run(View.java:16966)
10-12 15:23:45.644: E/AndroidRuntime(899):  at android.os.Handler.handleCallback(Handler.java:615)
10-12 15:23:45.644: E/AndroidRuntime(899):  at android.os.Handler.dispatchMessage(Handler.java:92)
10-12 15:23:45.644: E/AndroidRuntime(899):  at android.os.Looper.loop(Looper.java:137)
10-12 15:23:45.644: E/AndroidRuntime(899):  at android.app.ActivityThread.main(ActivityThread.java:4745)
10-12 15:23:45.644: E/AndroidRuntime(899):  at java.lang.reflect.Method.invokeNative(Native Method)
10-12 15:23:45.644: E/AndroidRuntime(899):  at java.lang.reflect.Method.invoke(Method.java:511)
10-12 15:23:45.644: E/AndroidRuntime(899):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786)
10-12 15:23:45.644: E/AndroidRuntime(899):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
10-12 15:23:45.644: E/AndroidRuntime(899):  at dalvik.system.NativeStart.main(Native Method)
10-12 15:23:45.644: E/AndroidRuntime(899): Caused by: java.lang.reflect.InvocationTargetException
10-12 15:23:45.644: E/AndroidRuntime(899):  at java.lang.reflect.Method.invokeNative(Native Method)
10-12 15:23:45.644: E/AndroidRuntime(899):  at java.lang.reflect.Method.invoke(Method.java:511)
10-12 15:23:45.644: E/AndroidRuntime(899):  at android.view.View$1.onClick(View.java:3586)
10-12 15:23:45.644: E/AndroidRuntime(899):  ... 11 more
10-12 15:23:45.644: E/AndroidRuntime(899): Caused by: java.lang.IllegalArgumentException: requested provider network doesn't exisit
10-12 15:23:45.644: E/AndroidRuntime(899):  at android.os.Parcel.readException(Parcel.java:1429)
10-12 15:23:45.644: E/AndroidRuntime(899):  at android.os.Parcel.readException(Parcel.java:1379)
10-12 15:23:45.644: E/AndroidRuntime(899):  at android.location.ILocationManager$Stub$Proxy.requestLocationUpdates(ILocationManager.java:646)
10-12 15:23:45.644: E/AndroidRuntime(899):  at android.location.LocationManager._requestLocationUpdates(LocationManager.java:660)
10-12 15:23:45.644: E/AndroidRuntime(899):  at android.location.LocationManager.requestLocationUpdates(LocationManager.java:482)
10-12 15:23:45.644: E/AndroidRuntime(899):  at com.desmill.taxi.activity.TaxiCaller.callTaxi(TaxiCaller.java:52)
10-12 15:23:45.644: E/AndroidRuntime(899):  ... 14 more
有什么想法吗?我如何让它显示其他的错误,它说…14更多。。。?
谢谢

您可以将logcat输出转储到文本文件中,您应该能够在那里读取它,尽管我不是肯定的。只需打开一个终端窗口,导航到包含adb可执行文件的目录(除非它在您的路径中),然后键入:

adb logcat-d>logcat.txt

清除logcat内容的另一个有用命令是:


adb logcat-c

您可以将logcat输出转储到文本文件中,您应该能够在那里读取它,尽管我不是肯定的。只需打开一个终端窗口,导航到包含adb可执行文件的目录(除非它在您的路径中),然后键入:

adb logcat-d>logcat.txt

清除logcat内容的另一个有用命令是:


adb logcat-c

这在2.2中适用于我+

    try {
        LocationManager locManager = (LocationManager) context.getSystemService(Context.LOCATION_SERVICE);
        gps_enabled = locManager.isProviderEnabled(LocationManager.GPS_PROVIDER);
    } catch (Exception e) {

    }

这在2.2中适用于我+

    try {
        LocationManager locManager = (LocationManager) context.getSystemService(Context.LOCATION_SERVICE);
        gps_enabled = locManager.isProviderEnabled(LocationManager.GPS_PROVIDER);
    } catch (Exception e) {

    }

问题的根源似乎在TaxiCaller类的第52行
位于com.desmill.taxi.activity.TaxiCaller.callTaxi(TaxiCaller.java:52)
是上面的代码吗?如果没有,请发布这个代码。这个问题也很类似:@Sam哦,显然我不知道如何阅读调试器。我认为错误发生在这个函数中,它以前在同一个类中像52一样被调用。事实是,当GPS被启用时,它会走得更远,并点击该功能。你救了我,谢谢你!!但现在的问题是:为什么这会导致4.1中的崩溃?locationManager.RequestLocationUpdate(locationManager.NETWORK\u提供程序,0,0,locationListener);错误列在我的原始帖子中:非法参数异常-请求的提供程序网络不存在。呵呵??我将对此进行研究,并将答案作为最后一个注释发布在这里。问题的根源似乎在课堂的第52行
位于com.desmill.taxi.activity.TaxiCaller.callTaxi(TaxiCaller.java:52)
是上面的代码吗?如果没有,请发布这个代码。这个问题也很类似:@Sam哦,显然我不知道如何阅读调试器。我认为错误发生在这个函数中,它以前在同一个类中像52一样被调用。事实是,当GPS被启用时,它会走得更远,并点击该功能。你救了我,谢谢你!!但现在的问题是:为什么这会导致4.1中的崩溃?locationManager.RequestLocationUpdate(locationManager.NETWORK\u提供程序,0,0,locationListener);错误列在我的原始帖子中:非法参数异常-请求的提供程序网络不存在。呵呵??我将对此进行研究,并将答案作为最后一条贴在这里。