【问题标题】:(TextView)findbyid crashes application Android.(TextView)findbyid 使应用程序 Android 崩溃。
【发布时间】:2012-05-26 01:44:39
【问题描述】:

当我尝试创建一个 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);       

}
}

我的应用程序关闭时的 logcat 是

05-26 01:43:23.018: E/AndroidRuntime(363): 致命异常: main 05-26 01:43:23.018: E/AndroidRuntime(363): java.lang.RuntimeException: 无法启动活动 ComponentInfo{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-26 01: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.invokeNative(Native Method) 05-26 01: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-26 01:43:23.018: E/AndroidRuntime(363): 在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626) 05-26 01:43:23.018: E/AndroidRuntime(363): at dalvik.system.NativeStart.main(Native Method) 05-26 01:43:23.018: E/AndroidRuntime(363): 由: java.lang.NullPointerException 引起 05-26 01:43:23.018: E/AndroidRuntime(363): at 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-26 01:43:23.018: E/AndroidRuntime(363): ... 11 更多

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

【问题讨论】:

    标签: android textview logcat


    【解决方案1】:

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

    【讨论】:

      【解决方案2】:

      setContentView(R.layout.advice);
      

      之前

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

      【讨论】:

        【解决方案3】:

        我认为您应该在使用 findViewById 之前设置内容视图。

        【讨论】:

          【解决方案4】:
          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);
             }}
          

          应该是这样的

          【讨论】:

            猜你喜欢
            • 2020-02-17
            • 1970-01-01
            • 1970-01-01
            • 1970-01-01
            • 1970-01-01
            • 2019-04-22
            • 2012-10-04
            • 1970-01-01
            相关资源
            最近更新 更多