0

이것은 매우 간단한 Android 앱입니다. 난 그냥 지금 안드로이드에 대한 코드를 작성 배우고 난 줄 이유는 확실하지 오전 :.OnClickListener를 만들 때 NullPointerException이 발생합니다 (Android)

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" 
xmlns:tools="http://schemas.android.com/tools" 
android:layout_width="match_parent" 
android:layout_height="match_parent" 
android:paddingBottom="@dimen/activity_vertical_margin" 
android:paddingLeft="@dimen/activity_horizontal_margin" 
android:paddingRight="@dimen/activity_horizontal_margin" 
android:paddingTop="@dimen/activity_vertical_margin" 
tools:context="com.thenewboston.jaredh.StartingPoint$PlaceholderFragment" > 

<TextView 
    android:layout_width="wrap_content" 
    android:layout_height="wrap_content" 
    android:layout_centerHorizontal="true" 
    android:text="@string/total" 
    android:textSize="40sp" 
    android:id="@+id/tvDisplay" 
    /> 

<Button 
    android:layout_width="250dp" 
    android:layout_height="wrap_content" 
    android:layout_alignLeft="@+id/tvDisplay" 
    android:layout_below="@+id/tvDisplay" 
    android:layout_gravity="center" 
    android:text="@string/addButton" 
    android:textSize="20sp" 
    android:id="@+id/bAdd" /> 

<Button 
    android:layout_width="250dp" 
    android:layout_height="wrap_content" 
    android:layout_alignLeft="@+id/bAdd" 
    android:layout_below="@+id/bAdd" 
    android:layout_gravity="center" 
    android:text="@string/subButton" 
    android:textSize="20sp" 
    android:id="@+id/bSub"/> 
: add.setOnClickListener (새 View.OnClickListener()는 NullPointerException이 발생 여기
public class StartingPoint extends ActionBarActivity{ 

int counter; 
Button add, sub; 
TextView display; 

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

    if (savedInstanceState == null) { 
     getSupportFragmentManager().beginTransaction() 
    .add(R.id.container, new PlaceholderFragment()).commit(); 
    } 

    counter = 0; 
    add = (Button) findViewById(R.id.bAdd); 
    sub = (Button) findViewById(R.id.bSub); 
    display = (TextView) findViewById(R.id.tvDisplay); 

    add.setOnClickListener(new View.OnClickListener() 
    { 

     @Override 
     public void onClick(View v) 
     { 
      counter++; 
      display.setText("Your total is " + counter); 
     } 
    }); 

    sub.setOnClickListener(new View.OnClickListener() 
    { 

     @Override 
     public void onClick(View v) 
     { 
      counter--; 
      display.setText("Your total is " + counter); 
     } 
    }); 

} 

는 XML 코드 왜 NullPointerExcepti 당신이 그것을 볼 수 있듯이 이

Logcat Error: 
     03-29 17:44:24.930: D/AndroidRuntime(25367): Shutting down VM 
03-29 17:44:24.930: W/dalvikvm(25367): threadid=1: thread exiting with uncaught exception (group=0x41831898) 
03-29 17:44:24.940: E/AndroidRuntime(25367): FATAL EXCEPTION: main 
03-29 17:44:24.940: E/AndroidRuntime(25367): java.lang.RuntimeException: Unable to start activity ComponentInf{com.thenewboston.jaredh/com.thenewboston.jaredh.StartingPoint}: java.lang.NullPointerException 
03-29 17:44:24.940: E/AndroidRuntime(25367): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2305) 
03-29 17:44:24.940: E/AndroidRuntime(25367): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2359) 
03-29 17:44:24.940: E/AndroidRuntime(25367): at android.app.ActivityThread.access$700(ActivityThread.java:165) 
03-29 17:44:24.940: E/AndroidRuntime(25367): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1326) 
03-29 17:44:24.940: E/AndroidRuntime(25367): at android.os.Handler.dispatchMessage(Handler.java:99) 
03-29 17:44:24.940: E/AndroidRuntime(25367): at android.os.Looper.loop(Looper.java:137) 
03-29 17:44:24.940: E/AndroidRuntime(25367): at android.app.ActivityThread.main(ActivityThread.java:5455) 
03-29 17:44:24.940: E/AndroidRuntime(25367): at java.lang.reflect.Method.invokeNative(Native Method) 
03-29 17:44:24.940: E/AndroidRuntime(25367): at java.lang.reflect.Method.invoke(Method.java:525) 
03-29 17:44:24.940: E/AndroidRuntime(25367): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1187) 
03-29 17:44:24.940: E/AndroidRuntime(25367): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1003) 
03-29 17:44:24.940: E/AndroidRuntime(25367): at dalvik.system.NativeStart.main(Native Method) 
03-29 17:44:24.940: E/AndroidRuntime(25367): Caused by: java.lang.NullPointerException 
03-29 17:44:24.940: E/AndroidRuntime(25367): at com.thenewboston.jaredh.StartingPoint.onCreate(StartingPoint.java:39) 
03-29 17:44:24.940: E/AndroidRuntime(25367): at android.app.Activity.performCreate(Activity.java:5372) 
03-29 17:44:24.940: E/AndroidRuntime(25367): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1104) 
03-29 17:44:24.940: E/AndroidRuntime(25367): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2267) 
03-29 17:44:24.940: E/AndroidRuntime(25367): ... 11 more 

단지 버튼 중 하나를 클릭 할 때 텍스트 필드에 1을 추가하는 매우 간단한 응용 프로그램입니다. 어떤 도움을 크게 apprecitated 수 있습니다. 그냥 확실 on이 발생합니다.

+1

logcat 오류를 게시하시기 바랍니다. –

+0

는 'activity_starting_point'에 대한이 코드입니까? –

+0

확률이 bAdd에 잘못되어 인스턴스를 생성 할 수 없습니다. 일부 logcat 오류 메시지를 게시합니다. 어디 떨어지는 지 알 수 없습니다. –

답변

2

당신이 제시 한 XML이 실제로 어떤 파일인지는 말할 것도없고 XML 텍스트가 유효하지 않은데도 불구하고 처음에 추가 한 PlaceholderFragment의 레이아웃이라고 생각합니다. 그러나 단편은 즉시 추가되지 않고 FragmentManager에 의해 추가되도록 예약됩니다. 따라서 UI 구성 요소를 즉시 찾으려고하면 액티비티가 수행되지 않고 findViewById에 의해 add 참조가 null로 설정됩니다.

관련 문제