Reputation: 3277
I'm trying to save data to my global variables by doing this:
public static String UnitCode;
public static String RDate;
public static String AArea;
final EditText unitCode = (EditText) findViewById(R.id.editText1);
final EditText reservationDate = (EditText) findViewById(R.id.editText2);
final EditText Area = (EditText) findViewById(R.id.editText3);
UnitCode = unitCode.getText().toString();
RDate = reservationDate.getText().toString();
AArea = Area.getText().toString();
this is inside my ReservationActivity.class.
However whenever I access it on my ReservationProcessActivity class:
UnitCode = ReservationActivity.UnitCode.toString();
RDate = ReservationActivity.RDate.toString();
Area = ReservationActivity.AArea.toString();
My android application suddenly crashes only when I uncomment the part in the ReservationProcessActivity, if I comment it, it works fine. Is what I'm doing wrong?
This is the logcat error:
02-06 11:50:10.956: E/AndroidRuntime(16482): FATAL EXCEPTION: main
02-06 11:50:10.956: E/AndroidRuntime(16482): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.appletest/com.example.appletest.ReservationProcessActivity}: java.lang.NullPointerException
02-06 11:50:10.956: E/AndroidRuntime(16482): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2308)
02-06 11:50:10.956: E/AndroidRuntime(16482): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2362)
02-06 11:50:10.956: E/AndroidRuntime(16482): at android.app.ActivityThread.access$700(ActivityThread.java:168)
02-06 11:50:10.956: E/AndroidRuntime(16482): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1329)
02-06 11:50:10.956: E/AndroidRuntime(16482): at android.os.Handler.dispatchMessage(Handler.java:99)
02-06 11:50:10.956: E/AndroidRuntime(16482): at android.os.Looper.loop(Looper.java:137)
02-06 11:50:10.956: E/AndroidRuntime(16482): at android.app.ActivityThread.main(ActivityThread.java:5493)
02-06 11:50:10.956: E/AndroidRuntime(16482): at java.lang.reflect.Method.invokeNative(Native Method)
02-06 11:50:10.956: E/AndroidRuntime(16482): at java.lang.reflect.Method.invoke(Method.java:525)
02-06 11:50:10.956: E/AndroidRuntime(16482): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1209)
02-06 11:50:10.956: E/AndroidRuntime(16482): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1025)
02-06 11:50:10.956: E/AndroidRuntime(16482): at dalvik.system.NativeStart.main(Native Method)
02-06 11:50:10.956: E/AndroidRuntime(16482): Caused by: java.lang.NullPointerException
02-06 11:50:10.956: E/AndroidRuntime(16482): at com.example.appletest.ReservationProcessActivity.onCreate(ReservationProcessActivity.java:102)
02-06 11:50:10.956: E/AndroidRuntime(16482): at android.app.Activity.performCreate(Activity.java:5372)
02-06 11:50:10.956: E/AndroidRuntime(16482): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1104)
02-06 11:50:10.956: E/AndroidRuntime(16482): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2270)
02-06 11:50:10.956: E/AndroidRuntime(16482): ... 11 more
This is my ReservationProcessActivity class:
public class ReservationProcessActivity extends Activity {
WebView webView;
HttpResponse response;
HttpClient httpclient;
List<NameValuePair> nameValuePairs;
StringBuffer buffer;
HttpPost httppost;
String UnitCode;
String RDate;
String Area;
@Override
protected void onCreate(Bundle savedInstanceState){
super.onCreate(savedInstanceState);
setContentView(R.layout.webpayment);
webView = (WebView)findViewById(R.id.webView1);
webView.getSettings().setLoadWithOverviewMode(true);
webView.getSettings().setUseWideViewPort(true);
webView.setWebChromeClient(new WebChromeClient());
webView.setWebViewClient(new MyBrowser());
webView.getSettings().setBuiltInZoomControls(false);
webView.getSettings().setJavaScriptEnabled(true);
webView.setHorizontalScrollBarEnabled(false);
UnitCode = ReservationActivity.UnitCode.toString();
RDate = ReservationActivity.RDate.toString();
Area = ReservationActivity.AArea.toString();
webView.loadUrl("http://google.com/");
}
}
the ReservationActivity class:
package com.example.appletest;
import android.app.ActionBar;
import android.app.Activity;
import android.content.Intent;
import android.content.SharedPreferences;
import android.graphics.Color;
import android.graphics.drawable.ColorDrawable;
import android.os.Bundle;
import android.support.v4.app.NavUtils;
import android.text.Html;
import android.view.Menu;
import android.view.MenuInflater;
import android.view.MenuItem;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.RadioButton;
public class ReservationActivity extends Activity {
public static String UnitCode;
public static String RDate;
public static String AArea;
@Override
protected void onCreate(Bundle savedInstanceState){
super.onCreate(savedInstanceState);
setContentView(R.layout.reservation_activity);
//button
final Button nextButton = (Button) findViewById(R.id.NextButton1);
//textbox
final EditText unitCode = (EditText) findViewById(R.id.editText1);
final EditText reservationDate = (EditText) findViewById(R.id.editText2);
final EditText Area = (EditText) findViewById(R.id.editText3);
nextButton.setOnClickListener(new View.OnClickListener(){
public void onClick(View v) {
// TODO Auto-generated method stub
UnitCode = unitCode.getText().toString();
RDate = reservationDate.getText().toString();
AArea = Area.getText().toString();
Intent i = new Intent(ReservationActivity.this, ReservationProcessActivity.class);
startActivity(i);
finish();
}
});
}
Upvotes: 1
Views: 425
Reputation: 60
I would recommend you by using getter and setter in case if you are playing with global variables. If I were you, I would have a seperate class for the global variables.
For example, have a seperate class called ReservationData.
public class ReservationData {
public static String UnitCode;
public static String RDate;
public static String AArea;
public static String getUnitCode() {
return UnitCode;
}
public static void setUnitCode(String unitCode) {
UnitCode = unitCode;
}
public static String getRDate() {
return RDate;
}
public static void setRDate(String RDate) {
ReservationData.RDate = RDate;
}
public static String getAArea() {
return AArea;
}
public static void setAArea(String AArea) {
ReservationData.AArea = AArea;
}
}
From the Activity, call the setter methods.
public class ReservationActivity extends Activity {
public static String UnitCode;
public static String RDate;
public static String AArea;
@Override
protected void onCreate(Bundle savedInstanceState){
super.onCreate(savedInstanceState);
setContentView(R.layout.reservation_activity);
//button
final Button nextButton = (Button) findViewById(R.id.NextButton1);
//textbox
final EditText unitCode = (EditText) findViewById(R.id.editText1);
final EditText reservationDate = (EditText) findViewById(R.id.editText2);
final EditText Area = (EditText) findViewById(R.id.editText3);
nextButton.setOnClickListener(new View.OnClickListener(){
public void onClick(View v) {
// TODO Auto-generated method stub
UnitCode = unitCode.getText().toString();
RDate = reservationDate.getText().toString();
AArea = Area.getText().toString();
//// Call Setter Methods
ReservationData.setAArea(AArea);
ReservationData.setRDate(RDate);
ReservationData.setUnitCode(UnitCode);
//// Call Setter Methods
Intent i = new Intent(ReservationActivity.this, ReservationProcessActivity.class);
startActivity(i);
finish();
}
});
}
In the ReservationProcessActivity class call the getter methods from ReservationData.
Instead of the following code,
UnitCode = ReservationActivity.UnitCode.toString();
RDate = ReservationActivity.RDate.toString();
Area = ReservationActivity.AArea.toString();
use these,
Area = ReservationData.setAArea(AArea);
RDate = ReservationData.setRDate(RDate);
UnitCode = ReservationData.setUnitCode(UnitCode);
Upvotes: 1
Reputation: 1283
change this code in ReservationProcessActivity :
UnitCode = ReservationActivity.UnitCode.toString();
RDate = ReservationActivity.RDate.toString();
Area = ReservationActivity.AArea.toString();
to :
UnitCode = ReservationActivity.UnitCode;
RDate = ReservationActivity.RDate;
Area = ReservationActivity.AArea;
Upvotes: 2
Reputation: 214
If ReservationProcessActivity has its onCreate() called before the onCreate of a ReservationActivity in the same jvm, then the static variable UnitCode in ReservationActivity will still be null. When you use this from ReservationProcessActivity like this:
UnitCode = ReservationActivity.UnitCode.toString();
That will cause your crash. I am not certain what the sequence of events in your activities is, but I think something like that is happening.
Upvotes: 1
Reputation: 283
I think the crash is because of NullPointerException. It's because you call findViewById too early. Usually, we use findViewById after Activity.setContentView has been called. see : enter link description here
Upvotes: 1