获取位置时出现 java.lang.NullPointerException

Posted

技术标签:

【中文标题】获取位置时出现 java.lang.NullPointerException【英文标题】:java.lang.NullPointerException when getting location 【发布时间】:2011-06-09 19:15:03 【问题描述】:

我有一些无法在模拟器中重新创建的问题,但我一直在 android 市场收到错误报告,我不知道如何解决...任何其他可能看到它的人都非常棒

有时此报告

java.lang.NullPointerException
at android.webkit.WebViewDatabase.getCacheTotalSize(WebViewDatabase.java:734)
at android.webkit.CacheManager.trimCacheIfNeeded(CacheManager.java:548)
at android.webkit.WebViewWorker.handleMessage(WebViewWorker.java:190)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:123)
at android.os.HandlerThread.run(HandlerThread.java:60)

有时还有这份报告

java.lang.RuntimeException: Unable to start activity ComponentInfopolis.koll/polis.koll.WebPageLoader: java.lang.IllegalArgumentException: provider==null
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2737)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2753)
at android.app.ActivityThread.access$2500(ActivityThread.java:129)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2107)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:143)
at android.app.ActivityThread.main(ActivityThread.java:4701)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:521)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.IllegalArgumentException: provider==null
at android.location.LocationManager.requestLocationUpdates(LocationManager.java:625)
at polis.koll.WebPageLoader.getLocation(WebPageLoader.java:54)
at polis.koll.WebPageLoader.onCreate(WebPageLoader.java:70)
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2701)

这是我的代码

    public class WebPageLoader extends Activity implements LocationListener
    public static String Android_ID = null;
    final Activity activity = this;
    private Location mostRecentLocation;

    private void CheckEnableGPS()
        String provider = Settings.Secure.getString(getContentResolver(),
          Settings.Secure.LOCATION_PROVIDERS_ALLOWED);
           if(!provider.equals(""))
               //GPS Enabled
               getLocation();
           else
            Intent intent = new Intent(Settings.ACTION_LOCATION_SOURCE_SETTINGS);
               startActivity(intent);
           

       


private void getLocation() 
    String provider = Settings.Secure.getString(getContentResolver(),
          Settings.Secure.LOCATION_PROVIDERS_ALLOWED);
           if(!provider.equals(""))
    LocationManager locationManager =
      (LocationManager)getSystemService(Context.LOCATION_SERVICE);
    Criteria criteria = new Criteria();
    criteria.setAccuracy(Criteria.ACCURACY_FINE);
    String bestprovider = locationManager.getBestProvider(criteria,true);
    locationManager.requestLocationUpdates(bestprovider, 1, 500, this);     
    mostRecentLocation = locationManager.getLastKnownLocation(LocationManager.GPS_PROVIDER);
         else
            Intent intent = new Intent(Settings.ACTION_LOCATION_SOURCE_SETTINGS);
               startActivity(intent);
           
  

@Override
public void onCreate(Bundle savedInstanceState)

    //AdManager.setTestDevices( new String[]  AdManager.TEST_EMULATOR  );
    super.onCreate(savedInstanceState);
    this.getWindow().requestFeature(Window.FEATURE_PROGRESS);
    setContentView(R.layout.main);

    getLocation();
    Android_ID = Secure.getString(getContentResolver(), Secure.ANDROID_ID);


    WebView webView = (WebView) findViewById(R.id.webView);
    webView.getSettings().setjavascriptEnabled(true);
    /** Allows JavaScript calls to access application resources **/
    webView.addJavascriptInterface(new JavaScriptInterface(), "android16");
    webView.setWebChromeClient(new WebChromeClient() 
        public void onProgressChanged(WebView view, int progress)
        
            activity.setTitle("Letar poliskontroller");
            activity.setProgress(progress * 100);


            if(progress == 100)
                activity.setTitle(R.string.app_name);
        
    );


    webView.setWebViewClient(new WebViewClient() 

        @Override
        public void onReceivedError(WebView view, int errorCode, String description, String failingUrl)
        
            // Handle the error
        


     // Testade att ta bort denna override för att få market länkar att fungera
     //   @Override
     //   public boolean shouldOverrideUrlLoading(WebView view, String url)
     //   
     //       view.loadUrl(url);
     //       return true;
     //   
    );

    if (Locale.getDefault().getLanguage().equals("sv"))
    //webView.loadUrl("file:///android_asset/android.html");
        webView.loadUrl("file:///android_asset/findgps_sv.html");
    else
    //webView.loadUrl("http://m.bryggplatsen.se/android/polis/index.php");
    //webView.loadUrl("file:///android_asset/android_en.html");
        webView.loadUrl("file:///android_asset/findgps_en.html");
    




    /** Sets up the interface for getting access to Latitude and Longitude data from device
     **/




private class JavaScriptInterface 
    public double getLatitude()
        return mostRecentLocation != null ? mostRecentLocation.getLatitude() : Double.NaN;
    

    public double getLongitude()
        return mostRecentLocation != null ? mostRecentLocation.getLongitude() : Double.NaN;
    


    public String getAndroid_ID()
        return Android_ID;
    

     public void sharethisapp()
     startActivity(Intent.createChooser(sharespotIntent(), "Share this warning"));
     
  


@Override
public void onLocationChanged(Location location) 
    // TODO Auto-generated method stub

    getLocation();
    //CheckEnableGPS();


@Override
public void onProviderDisabled(String provider) 
    // TODO Auto-generated method stub
    getLocation();


@Override
public void onProviderEnabled(String provider) 
    // TODO Auto-generated method stub
    getLocation();


@Override
public void onStatusChanged(String provider, int status, Bundle extras) 
    // TODO Auto-generated method stub
    getLocation();



@Override
public boolean onCreateOptionsMenu(Menu menu) 
    super.onCreateOptionsMenu(menu);
    MenuItem item = menu.add("Shut down");
    item.setIcon(R.drawable.exit);

    item = menu.add("Share");
    item.setIcon(R.drawable.m_share);

    item = menu.add("Fix GPS");
    item.setIcon(R.drawable.globe);
    return true;


@Override
public boolean onOptionsItemSelected(MenuItem item) 
    if (item.getTitle() == "Shut down") 
        System.exit(0);
        finish();
    
    if (item.getTitle() == "Fix GPS") 
        getLocation();
    
    if (item.getTitle() == "Share") 
        if (Locale.getDefault().getLanguage().equals("sv"))
        startActivity(Intent.createChooser(shareIntent(), "Dela denna app"));
        else
        startActivity(Intent.createChooser(shareIntent(), "Share this app"));
        
    
    return true;


private Intent shareIntent() 
        Intent shareIntent = new Intent(android.content.Intent.ACTION_SEND);
        shareIntent.setType("text/plain");      
    if (Locale.getDefault().getLanguage().equals("sv"))
        shareIntent.putExtra(android.content.Intent.EXTRA_SUBJECT, "Testa denna android app...");
        return shareIntent.putExtra(android.content.Intent.EXTRA_TEXT, "index.php");
    else
        shareIntent.putExtra(android.content.Intent.EXTRA_SUBJECT, "Try this cool android app...");
        return shareIntent.putExtra(android.content.Intent.EXTRA_TEXT, "index_en.php");         
    




private Intent sharespotIntent() 
    Intent sharespotIntent = new Intent(android.content.Intent.ACTION_SEND);
    sharespotIntent.setType("text/plain");      
if (Locale.getDefault().getLanguage().equals("sv"))
    sharespotIntent.putExtra(android.content.Intent.EXTRA_SUBJECT, " la just upp en ny varning i appen Polisradar");
    return sharespotIntent.putExtra(android.content.Intent.EXTRA_TEXT, "warn.php?lat=" + mostRecentLocation.getLatitude() + "&lng=" + mostRecentLocation.getLongitude() + "");
else
    sharespotIntent.putExtra(android.content.Intent.EXTRA_SUBJECT, " just added a new warning in the app Policeradar");
    return sharespotIntent.putExtra(android.content.Intent.EXTRA_TEXT, "warn_en.php?lat=" + mostRecentLocation.getLatitude() + "&lng=" + mostRecentLocation.getLongitude() + "");       
    

【问题讨论】:

这感觉不是你的错。在异常的来源方面是否存在任何模式:某些设备、某些制造商、某些 Android 版本等? 不,我在报告中看不到他们有哪些手机或安卓系统。在我自己的带有 android 2.2 的手机 (HTC Desire) 上,我有时注意到应用程序有时但不是经常停止,不会冻结或崩溃,只是不进入下一步。 【参考方案1】:

如果请求的名称不在数据库中,则方法 Settings.Secure.getString() 可以返回 null。不过,我不知道为什么找不到 Settings.Secure.LOCATION_PROVIDERS_ALLOWED。但是,您的代码在检查它是否不是空字符串之前不会检查(在 getLocation() 中)提供程序是否为空。我认为这是您的第二个例外的根源。

框架深处看似随机的错误也可能是由于尝试在不支持代码中某些内容的操作系统版本上运行您的应用程序造成的。确保您的代码根据您在清单中设置的 minSdkVersion 进行编译,而不仅仅是 targetSdkVersion。

【讨论】:

好的,我试着让提供者不返回 null 开始,我会报告它的进展情况 @Ted Hopp - 你认为这可以解决问题吗? if(provider==null) 提供者 = ""; 试试“if (!(provider == null || provider.equals(""))) ... ”。这应该可以解决问题。 不,仍然得到这个错误:Caused by: java.lang.IllegalArgumentException: provider==null 我猜它的这一行:String provider = Settings.Secure.getString(getContentResolver(), Settings.Secure.LOCATION_PROVIDERS_ALLOWED);【参考方案2】:

关于这个问题的注释。我不知道这是否是您的问题,但我正在考虑在应用程序之间共享一些文件并尝试修改我的 AndroidManifest.xml 文件中的 android:sharedUserId 属性。一旦我这样做了,我得到了与您报告的完全相同的错误,并且我的应用程序无法正常启动(似乎是由于 AdRequest 失败)。即使从清单中删除 sharedUserId 属性后,我仍然会收到错误,尽管我认为它来自首选项数据库。

最重要的是,一旦部署应用程序,就不要更改它的 sharedUserId 属性,否则您将需要一个卸载/重新安装周期才能让一切恢复正常。

【讨论】:

以上是关于获取位置时出现 java.lang.NullPointerException的主要内容,如果未能解决你的问题,请参考以下文章

获取位置时出现 java.lang.NullPointerException

在服务类中添加权限以获取位置时出现 java.lang.ClassCastException

在 setInterval 方法中使用 getCurrentPosition geoLocation 函数通过 React-Native 获取用户当前位置时出现问题

尝试在 Flutter 中获取地点的自动完成位置并在点击的地点上显示详细信息时出现空安全错误

Android开发中java.lang.RuntimeException: Unable to start activity ComponentInfo{xxx}

在 Android N 中调用位置时出现空点异常。 [重复]