アプリを実行している間、常にこの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)
_public class Distance extends Application
_
コンパイラエラーが解消されると考えるからといって、クラスをランダムに拡張しないでください。ここには有効なApplication
サブクラスがなく、適切に使用していません。
ステップ#1:Distance
から_extends Application
_を削除します。
ステップ#2:getDistance()
にContext
をパラメーターとして使用させ、MySingleton
でそれを使用させる
ステップ#3:MainActivity
にgetApplicationContext()
をgetDistance()
にContext
として渡させる
これは実際には答えではなく、単なるアイデアです。
私は同じ問題を抱えていました(それがこの質問にたどり着いた方法です)。私の問題は実際には非常に簡単でした。シングルトンでプライベートコンテキストを設定する前に、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() );
だから私は自分の問題を共有し、それがあなたにいくつかのアイデアをもたらすことを望んでいます。幸運を。