NullPointerException в TextView внутри onResume()Android

Форум для тех, кто программирует под Android
Ответить
Anonymous
 NullPointerException в TextView внутри onResume()

Сообщение Anonymous »

Поток моего кода — onCreate(), onResume() и onPause(). На самом деле у меня есть две проблемы, но это самая насущная из двух, потому что она приводит к сбою моего приложения.
onCreate():
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
sensorManager = (SensorManager) getSystemService(Context.SENSOR_SERVICE);

setContentView(R.layout.activity_main);
tv1 = (TextView) findViewById(R.id.tv1);
tv1.append("placeholder");
tv1.setVerticalScrollBarEnabled(true);
//rest of the code dealing with files and sensors. tv1 not used.

onResume():
@Override
protected void onResume() {

super.onResume();

setContentView(R.layout.activity_main);
TextView tv = findViewById(R.id.tv1); // Added to see if it helps with error. It doesn't.
tv.setVerticalScrollBarEnabled(true);

File folder = new File(getFilesDir()+ "/YYY");
File file = new File(folder.getAbsolutePath()+"/XXX.txt");

try
{
//some other file logic.
String line = reader.readLine();
while(line != null)
{
line = reader.readLine();
tv.append(line); // ERROR HERE!
}
//Other irrelevant code here. Buffer closing stuff.
} catch (Exception e)
{
System.out.println("IO Read Error: "+e.toString());
//e.printStackTrace();
}
}

onPause():
@Override
protected void onPause() {
super.onPause();
System.out.println("activity paused");
}

Ошибка (указанная в комментарии в onResume()) текст:
E/AndroidRuntime: FATAL EXCEPTION: main
Process: com.example.surfacesmoothness1, PID: 19577
java.lang.RuntimeException: Unable to resume activity {com.example.YYY/com.example.YYY.MainActivity}: java.lang.NullPointerException: Attempt to invoke interface method 'int java.lang.CharSequence.length()' on a null object reference
at android.app.ActivityThread.performResumeActivity(ActivityThread.java:3784)
at android.app.ActivityThread.handleResumeActivity(ActivityThread.java:3816)
at android.app.servertransaction.ResumeActivityItem.execute(ResumeActivityItem.java:51)
at android.app.servertransaction.TransactionExecutor.executeLifecycleState(TransactionExecutor.java:145)
at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:70)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1808)
at android.os.Handler.dispatchMessage(Handler.java:106)
at android.os.Looper.loop(Looper.java:193)
at android.app.ActivityThread.main(ActivityThread.java:6669)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:493)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:858)
Caused by: java.lang.NullPointerException: Attempt to invoke interface method 'int java.lang.CharSequence.length()' on a null object reference
at android.widget.TextView.append(TextView.java:5219)
at com.example.surfacesmoothness1.MainActivity.onResume(MainActivity.java:208)
at android.app.Instrumentation.callActivityOnResume(Instrumentation.java:1412)
at android.app.Activity.performResume(Activity.java:7292)
at android.app.ActivityThread.performResumeActivity(ActivityThread.java:3776)
at android.app.ActivityThread.handleResumeActivity(ActivityThread.java:3816) 
at android.app.servertransaction.ResumeActivityItem.execute(ResumeActivityItem.java:51) 
at android.app.servertransaction.TransactionExecutor.executeLifecycleState(TransactionExecutor.java:145) 
at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:70) 
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1808) 
at android.os.Handler.dispatchMessage(Handler.java:106) 
at android.os.Looper.loop(Looper.java:193) 
at android.app.ActivityThread.main(ActivityThread.java:6669) 
at java.lang.reflect.Method.invoke(Native Method) 
at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:493) 
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:858) 

Я не уверен, что делаю неправильно. Я подозреваю, что это глупая ошибка, но в данный момент она ускользает от меня. Возможно, это связано с другой моей проблемой - даже когда я использую эмулятор, чтобы вернуться на главный экран из приложения (выйти из приложения), активность не проходит. Я по-прежнему вижу, что все операторы печати/отладки в onCreate() выводятся на консоль. Но я думаю по одному.
Что я делаю не так?
Изменить: вот мой XML :








Подробнее здесь: https://stackoverflow.com/questions/791 ... e-onresume
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «Android»