Welcome to the Treehouse Community

Want to collaborate on code errors? Have bugs you need feedback on? Looking for an extra set of eyes on your latest project? Get support with fellow developers, designers, and programmers of all backgrounds and skill levels here with the Treehouse Community! While you're at it, check out some resources Treehouse students have shared here.

Looking to learn something new?

Treehouse offers a seven day free trial for new students. Get access to thousands of hours of content and join thousands of Treehouse students and alumni in the community today.

Start your free trial

Android Android Activity Lifecycle The Activity Lifecycle Saving and Retrieving Instance State

Android Activity Lifecycle: code challenge 2 of 3

When attempting to work my way through the code challenge I am greeted by this compiler error

JavaTester.java:95: error: KEY_USERENTRY has private access in MainActivity
if (bundle.getInt(MainActivity.KEY_USERENTRY) == 10 && bundle.correctKey) {
                              ^
1 error
MainActivity.java
import android.content.Intent;
import android.view.View;

public class MainActivity extends Activity {

  public TextView mTextView;
  private static final String KEY_USERENTRY = "KEY_USERENTRY";

  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    mTextView = (TextView) findViewById(R.id.textView);
  }

    @Override
    protected void onSaveInstanceState(Bundle outState) {
        super.onSaveInstanceState(outState);
        outState.putInt(KEY_USERENTRY, 10);

    }

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

    }
}

1 Answer

Ben Deitch
STAFF
Ben Deitch
Treehouse Teacher

Looking into it!

Change this to public for now: private static final String KEY_USERENTRY = "KEY_USERENTRY";

That worked! Under normal circumstances that would be a private field right?

Ben Deitch
Ben Deitch
Treehouse Teacher

Yep, private is probably the better choice since our Bundle is specific to this Class. There could be situations where you'd want it to be public, and public wouldn't be an incorrect choice here either, but it's not a big deal either way.