(TextView)findbyid使Android应用程序崩溃。

(TextView)findbyid使Android应用程序崩溃。,android,textview,logcat,Android,Textview,Logcat,当我尝试创建textview并将其链接到应用程序中的XML组件时,我的应用程序似乎崩溃了。我使用的代码是: public class WorkoutAdvice extends Activity { TextView adviceshow; @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); String[] advice = getRes

当我尝试创建textview并将其链接到应用程序中的XML组件时,我的应用程序似乎崩溃了。我使用的代码是:

public class WorkoutAdvice extends Activity {
TextView adviceshow;
@Override
public void onCreate(Bundle savedInstanceState) 
{
    super.onCreate(savedInstanceState);
    String[] advice = getResources().getStringArray(R.array.races_array);
    Random rand = new Random(); 
    int ad = rand.nextInt(5);
    String gen = advice[ad];
    adviceshow = (TextView)findViewById(R.id.advice);
    adviceshow.setText(gen);
    requestWindowFeature(Window.FEATURE_NO_TITLE);
    getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN,WindowManager.LayoutParams.FLAG_FULLSCREEN);
    setContentView(R.layout.advice);       

}
}
我的应用程序关闭时的日志是

05-26 01:43:23.018:E/AndroidRuntime(363):致命异常:主 05-26 01:43:23.018:E/AndroidRuntime(363):java.lang.RuntimeException:无法启动活动组件信息{com.b00348312.workout/com.b00348312.workout.WorkoutAdvice}:java.lang.NullPointerException 05-26 01:43:23.018:E/AndroidRuntime(363):在android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2663) 05-26 01:43:23.018:E/AndroidRuntime(363):在android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2679) 05-26 01:43:23.018:E/AndroidRuntime(363):在android.app.ActivityThread.access$2300(ActivityThread.java:125) 05-26 01:43:23.018:E/AndroidRuntime(363):在android.app.ActivityThread$H.handleMessage(ActivityThread.java:2033) 05-26 01:43:23.018:E/AndroidRuntime(363):在android.os.Handler.dispatchMessage(Handler.java:99)上 05-2601:43:23.018:E/AndroidRuntime(363):在android.os.Looper.loop(Looper.java:123)上 05-26 01:43:23.018:E/AndroidRuntime(363):位于android.app.ActivityThread.main(ActivityThread.java:4627) 05-26 01:43:23.018:E/AndroidRuntime(363):位于java.lang.reflect.Method.Invokenactive(本机方法) 05-2601:43:23.018:E/AndroidRuntime(363):在java.lang.reflect.Method.invoke(Method.java:521) 05-26 01:43:23.018:E/AndroidRuntime(363):在com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868) 05-2601:43:23.018:E/AndroidRuntime(363):位于com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626) 05-26 01:43:23.018:E/AndroidRuntime(363):在dalvik.system.NativeStart.main(本机方法) 05-26 01:43:23.018:E/AndroidRuntime(363):由以下原因引起:java.lang.NullPointerException 05-26 01:43:23.018:E/AndroidRuntime(363):在com.b00348312.workout.WorkoutAdvice.onCreate(WorkoutAdvice.java:22) 05-26 01:43:23.018:E/AndroidRuntime(363):在android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047) 05-26 01:43:23.018:E/AndroidRuntime(363):在android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2627) 05-2601:43:23.018:E/AndroidRuntime(363):。。。还有11个

应用程序在没有处理findbyID行的语句的情况下工作,findbyID行在应用程序的其他部分工作

setContentView(R.layout.advice);
之前

adviceshow = (TextView)findViewById(R.id.advice);

我认为在使用findViewById之前应该设置ContentView

在通过调用
setContentView
实际设置活动内容之前,找不到任何视图。调用
setContentView
后,您可以尝试查找
TextView
。请注意,在此调用之前,
活动
完全不知道它将绑定到哪些XML布局(如果有)

应该是这样的

public class WorkoutAdvice extends Activity {
TextView adviceshow;
@Override
public void onCreate(Bundle savedInstanceState) 
{
   super.onCreate(savedInstanceState);
    setContentView(R.layout.advice);
requestWindowFeature(Window.FEATURE_NO_TITLE);
getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN,WindowManager.LayoutParams.FLAG_FULLSCREEN);
 adviceshow = (TextView)findViewById(R.id.advice);
    String[] advice = getResources().getStringArray(R.array.races_array);
    Random rand = new Random(); 
    int ad = rand.nextInt(5);
    String gen = advice[ad];

    adviceshow.setText(gen);
   }}