web-dev-qa-db-ja.com

nullオブジェクト参照のgetApplicationContext()

アプリを実行している間、常にこのJava.lang.NullPointerException: Attempt to invoke virtual method 'Android.content.Context Android.content.Context.getApplicationContext()' on a null object referenceエラーが発生します。私は他の答えを見ましたが、それらの答えの使い方を理解していませんでした。アクティビティによる呼び出しがないため、コンテキストに問題があることを理解したので、アクティビティコンテキストを成功させずに渡そうとしました...これは私のコードです:

[〜#〜] edit [〜#〜]私はすでにあなたの答えをしましたが、うまくいきませんでしたので、削除しましたこれは解決策ではないと思ったからです。あなたの答えのために、コードを更新しました(コンテキストを距離クラスのパーマーとして> MySingletonクラスに...)

public class MainActivity extends AppCompatActivity {

    private Button b;
    private TextView t;
    private LocationManager locationManager;
    private LocationListener listener;


    @Override
    protected void onCreate(@Nullable Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        setContentView(R.layout.activity_main);


        t = (TextView) findViewById(R.id.textView);
        b = (Button) findViewById(R.id.button);

        locationManager = (LocationManager) getSystemService(LOCATION_SERVICE);


        listener = new LocationListener() {
            @Override
            public void onLocationChanged(Location location) {
                Log.d("Co", "onLocationChanged");
                Distance distance=new Distance();
                t.setText("\n " + location.getLongitude() + " " + location.getLatitude()+"\n "+distance.getDistance(location));

                Location l2=new Location("");

                //float distance=location.distanceTo(l2);
                Log.d("Co", String.valueOf(distance));
            }

            @Override
            public void onStatusChanged(String s, int i, Bundle bundle)   {

            }

            @Override
            public void onProviderEnabled(String s) {

            }

            @Override
            public void onProviderDisabled(String s) {

                Intent i = new Intent(Settings.ACTION_LOCATION_SOURCE_SETTINGS);
                startActivity(i);
            }
        };

        configure_button();
    }

    @Override
    public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
        switch (requestCode){
            case 10: {
                configure_button();
                Log.d("Co", "premmsioenChecks");

            }
            break;
            default:
                break;
        }
    }

    public void configure_button(){
        // first check for permissions
        if (ActivityCompat.checkSelfPermission(this, Manifest.permission.ACCESS_FINE_LOCATION) != PackageManager.PERMISSION_GRANTED && ActivityCompat.checkSelfPermission(this, Manifest.permission.ACCESS_COARSE_LOCATION) != PackageManager.PERMISSION_GRANTED) {
            if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
                requestPermissions(new String[]{Manifest.permission.ACCESS_COARSE_LOCATION,Manifest.permission.ACCESS_FINE_LOCATION,Manifest.permission.INTERNET}
                        ,10);
                Log.d("Co", "premmsioen");

            }
            return;
        }
        // this code won't execute IF permissions are not allowed, because in the line above there is return statement.
        b.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                //noinspection MissingPermission


                locationManager.requestLocationUpdates(LocationManager.GPS_PROVIDER, 0, 0, listener);
                locationManager.requestLocationUpdates(LocationManager.NETWORK_PROVIDER, 0, 0, listener);
                Log.d("Co", "onClick");
                Location l2=new Location("");


            }
        });
    }

}

パブリッククラスDistance {

static  String url = "";
static String result="";

public  String getDistance(Location location,Context context) {

    Log.d("app","getDistance");






            String origins=location.getLatitude()+","+location.getLongitude();

            url="https://maps.googleapis.com/maps/api/distancematrix/json?&origins="+origins+"&destinations="+destinations;
            Log.d("URL",url);
            JsonObjectRequest jsObjRequest = new JsonObjectRequest

                    (Request.Method.GET, url, null, new Response.Listener<JSONObject>() {

                        @Override
                        public void onResponse(JSONObject response) {
                            Log.d("app","onRespone");

                            String distance=getText(response);
                            if (distance.contains("Error")) {
                                result=distance;
                                return;
                            }
                            else {
                                if (distance.contains("km")) {
                                    int meters = Integer.parseInt(distance.replaceAll("[\\D]", "")) * 1000;
                                   result= "The distance is " + meters + " meters";
                                    return;
                                }
                                Log.d("7", String.valueOf(Integer.parseInt(distance.replaceAll("[\\D]", ""))));

                                result= "The distance is " + distance;
                            }



                        }
                    }, new Response.ErrorListener() {

                        @Override
                        public void onErrorResponse(VolleyError error) {
                            Log.d("app","Error Respone");

                        }
                    }
                    );
            MySingleton.getInstance(context).addToRequestque(jsObjRequest);
    return result;
        }




public  String getText(JSONObject response)
{
    String  text="";
    try {

        JSONArray rows = response.getJSONArray("rows");
        Log.d("1", rows.toString());
        if(rows.toString().contains("[]"))  return text="Error";
        JSONObject elements = rows.getJSONObject(0);
        Log.d("2", elements.toString());
        rows = elements.getJSONArray("elements");
        Log.d("3", rows.toString());
        elements  = rows.getJSONObject(0);
        Log.d("4", elements.toString());
        Log.d("Error1","Error is @"+elements.getString("status"));
        if( elements.getString("status").contains("OK"))
        {
            JSONObject d = elements.getJSONObject("distance");
            Log.d("5", d.toString());
            text = d.getString("text");
        }
        else {
            Log.d("Error2", elements.getString("status"));
            text = "Error-" + elements.getString("status");
        }

    }
    catch (JSONException e)
    {
        text="Some error ocuerd";
    }
    return text;
}

}

public class MySingleton {
    private static MySingleton mInstance;
    private RequestQueue requestQueue;
    public static Context mCtx;
    private MySingleton(Context context)
    {
        mCtx=context;
        requestQueue= getRequestQueue();
    }

    public RequestQueue getRequestQueue() {
        if(requestQueue==null) {
            requestQueue = Volley.newRequestQueue(mCtx.getApplicationContext());
        }
        return requestQueue;
    }
    public static synchronized MySingleton getInstance(Context context)
    {
        if(mInstance==null)
        {
            mInstance=new MySingleton(context);
        }
        return mInstance;
    }
    public <T> void addToRequestque(Request<T> request)
    {
        requestQueue.add(request);
    }

}

これはlogcatです

06-24 16:19:26.771 25300-25300/com.example.elicahi.gateor D/Co: onClick
06-24 16:19:27.556 25300-25300/com.example.elicahi.gateor D/Co: onLocationChanged

06-24 16:19:27.579 25300-25300/com.example.elicahi.gateor D/AndroidRuntime: Shutting down VM
06-24 16:19:27.579 25300-25300/com.example.elicahi.gateor E/AndroidRuntime: FATAL EXCEPTION: main
                                                                            Process: com.example.elicahi.gateor, PID: 25300
                                                                            Java.lang.NullPointerException: Attempt to invoke virtual method 'Android.content.Context Android.content.Context.getApplicationContext()' on a null object reference
                                                                                at Android.content.ContextWrapper.getApplicationContext(ContextWrapper.Java:107)
                                                                                at com.example.elicahi.gateor.MySingleton.getRequestQueue(MySingleton.Java:24)
                                                                                at com.example.elicahi.gateor.MySingleton.<init>(MySingleton.Java:19)
                                                                                at com.example.elicahi.gateor.MySingleton.getInstance(MySingleton.Java:32)
                                                                                at com.example.elicahi.gateor.Distance.getDistance(Distance.Java:79)
                                                                                at com.example.elicahi.gateor.MainActivity$1.onLocationChanged(MainActivity.Java:54)
                                                                                at Android.location.LocationManager$ListenerTransport._handleMessage(LocationManager.Java:285)
                                                                                at Android.location.LocationManager$ListenerTransport.-wrap0(LocationManager.Java)
                                                                                at Android.location.LocationManager$ListenerTransport$1.handleMessage(LocationManager.Java:230)
                                                                                at Android.os.Handler.dispatchMessage(Handler.Java:102)
                                                                                at Android.os.Looper.loop(Looper.Java:148)
                                                                                at Android.app.ActivityThread.main(ActivityThread.Java:5417)
                                                                                at Java.lang.reflect.Method.invoke(Native Method)
                                                                                at com.Android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.Java:726)
                                                                                at com.Android.internal.os.ZygoteInit.main(ZygoteInit.Java:616)
10
user5209063
_public class Distance extends Application
_

コンパイラエラーが解消されると考えるからといって、クラスをランダムに拡張しないでください。ここには有効なApplicationサブクラスがなく、適切に使用していません。

ステップ#1:Distanceから_extends Application_を削除します。

ステップ#2:getDistance()Contextをパラメーターとして使用させ、MySingletonでそれを使用させる

ステップ#3:MainActivitygetApplicationContext()getDistance()Contextとして渡させる

11
CommonsWare

これは実際には答えではなく、単なるアイデアです。

私は同じ問題を抱えていました(それがこの質問にたどり着いた方法です)。私の問題は実際には非常に簡単でした。シングルトンでプライベートコンテキストを設定する前に、RequestQueueを設定しようとしました。

  private MySingleton(Context context) {
    ctx = context; // queue = getRequestQueue();    <--- queue first but it needs context.
    queue = getRequestQueue();    // ctx = context;   <--- ctx being set here. queue can't find context.
 }

public synchronized static MySingleton getInstance(Context context) {
    if (instance == null) {
        instance = new MySingleton(context);
    }
    return instance;
}

private RequestQueue getRequestQueue() {
    if (queue == null) {
        queue = Volley.newRequestQueue( ctx.getApplicationContext() ); // <--- Here is the crash;
    }
    return queue;
}

また、この問題を見つける前に、パラメーターとして渡されるときにコンテキストがnullでないことを確認しました。つまり、問題はMySingletonコードのどこかにある必要がありました。

// This code is run before MySingleton.getInstance() wherever it is in your app;
Context testParameter = getBaseContext();
Log.d("DEBUG_CONTEXT", testParameter.toString() );

だから私は自分の問題を共有し、それがあなたにいくつかのアイデアをもたらすことを望んでいます。幸運を。

0
Lucas Nantes