마스터Q&A 안드로이드는 안드로이드 개발자들의 질문과 답변을 위한 지식 커뮤니티 사이트입니다. 안드로이드펍에서 운영하고 있습니다. [사용법, 운영진]

에러는 없는데 실행만 하면 강제종료됩니다 ㅠㅠ

0 추천

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

        if (savedInstanceState == null) {
            getSupportFragmentManager().beginTransaction()
                    .add(R.id.container, new PlaceholderFragment())
                    .commit();
           
        }
       
        Button bt_linktoblog = (Button) this.findViewById(R.id.button2);
        bt_linktoblog.setOnClickListener(new OnClickListener() {
   
   @Override
   public void onClick(View v) {
    // TODO Auto-generated method stub
    Intent it_linktoblog = new Intent(Intent.ACTION_VIEW,Uri.parse("
http://blog.naver.com/"));
    startActivity(it_linktoblog);
   }
  });

      
    }
 
오류는 없는데 설치하고 나면 강제종료되네요ㅠㅠ
혹시 이유를 알 수 있을까요?
저 빨간 부분을 주석으로 바꿨을 때에는 에러가 없어요 ㅠㅠ
 
05-30 17:55:31.385: D/ActivityThread(29388): setTargetHeapUtilization:0.25
05-30 17:55:31.385: D/ActivityThread(29388): setTargetHeapConcurrentStart:2097152
05-30 17:55:31.385: D/HyLog(29388): I : /data/font/config/dfactpre.dat, No such file or directory (2)
05-30 17:55:31.475: D/AndroidRuntime(29388): Shutting down VM
05-30 17:55:31.475: W/dalvikvm(29388): threadid=1: thread exiting with uncaught exception (group=0x41974e48)

05-30 17:55:31.475: E/AndroidRuntime(29388): FATAL EXCEPTION: main
05-30 17:55:31.475: E/AndroidRuntime(29388): Process: com.dw.contacts.countrycode.change, PID: 29388
05-30 17:55:31.475: E/AndroidRuntime(29388): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.dw.contacts.countrycode.change/com.dw.contacts.countrycode.change.MainActivity}: java.lang.NullPointerException
05-30 17:55:31.475: E/AndroidRuntime(29388):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2202)
05-30 17:55:31.475: E/AndroidRuntime(29388):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2252)
05-30 17:55:31.475: E/AndroidRuntime(29388):  at android.app.ActivityThread.access$800(ActivityThread.java:139)
05-30 17:55:31.475: E/AndroidRuntime(29388):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1200)
05-30 17:55:31.475: E/AndroidRuntime(29388):  at android.os.Handler.dispatchMessage(Handler.java:102)
05-30 17:55:31.475: E/AndroidRuntime(29388):  at android.os.Looper.loop(Looper.java:136)
05-30 17:55:31.475: E/AndroidRuntime(29388):  at android.app.ActivityThread.main(ActivityThread.java:5103)
05-30 17:55:31.475: E/AndroidRuntime(29388):  at java.lang.reflect.Method.invokeNative(Native Method)
05-30 17:55:31.475: E/AndroidRuntime(29388):  at java.lang.reflect.Method.invoke(Method.java:515)
05-30 17:55:31.475: E/AndroidRuntime(29388):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:790)
05-30 17:55:31.475: E/AndroidRuntime(29388):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:606)
05-30 17:55:31.475: E/AndroidRuntime(29388):  at dalvik.system.NativeStart.main(Native Method)
05-30 17:55:31.475: E/AndroidRuntime(29388): Caused by: java.lang.NullPointerException
05-30 17:55:31.475: E/AndroidRuntime(29388):  at com.dw.contacts.countrycode.change.MainActivity.onCreate(MainActivity.java:36)
05-30 17:55:31.475: E/AndroidRuntime(29388):  at android.app.Activity.performCreate(Activity.java:5275)
05-30 17:55:31.475: E/AndroidRuntime(29388):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087)
05-30 17:55:31.475: E/AndroidRuntime(29388):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2166)
05-30 17:55:31.475: E/AndroidRuntime(29388):  ... 11 more
delcube (330 포인트) 님이 2014년 5월 30일 질문

2개의 답변

0 추천

bt_linktoblog이 재대로 초기화 되지 못한걸로 보입니다~!

해당 레이아웃에 button2가 존재 하는지 확인 해보세요~!

ThisPlus (46,920 포인트) 님이 2014년 5월 30일 답변
button2는 확실히 존재합니다!
nullpointer 익셉션이 날 부분은 버튼 부분 밖에 없어요~~!
리스너 안의 부분은 클릭을 실행 해야 실행 디는 부분이므로 엑티비티 실행과는 전혀 무관합니다~!
그냥 xml을 올려 주심 확실 할 듯 합니다.
0 추천

로그캣이 떡하니 써져있네요;;;;;;;;;;;;;;;

 

05-30 17:55:31.475: E/AndroidRuntime(29388): Caused by: java.lang.NullPointerException
05-30 17:55:31.475: E/AndroidRuntime(29388):  at com.dw.contacts.countrycode.change.MainActivity.onCreate(MainActivity.java:36)

랍니다.

NullPointerException이요.

 

정확한 줄번호는 안나와있지만 보니까

startActivity(it_linktoblog);

이 부분이거나,

bt_linktoblog.setOnClickListener(new OnClickListener() {

이 부분이겠네요.

 

 

그리고 말씀하시는 '에러가 없다.'는건 정확히 말하면

'컴파일 상 에러가 없다.'

즉 '문법상 오류가 없다.'는 뜻이지,

진짜 에러가 없다는 뜻은 아닙니다.

 

로그캣에 떡하니 에러를 찍어주는건 에러가 안보인다고는 말 못하죠.

로그캣에서도 명확히 안나오는 fatal 에러라던가 그런거면 모르겠지만요...

Jinthree (8,980 포인트) 님이 2014년 5월 30일 답변
ㅠㅠ 정말 초짜라 로그 보는법도 잘 모릅니다 ㅠㅠ
해결하기 위해서는 어떻게 해야하는지 조언좀 부탁드릴게요ㅠㅠ
일단은 문법상 에러가 없다는 거면 R.id.button2에서는 오류가 안난다는 뜻이니, 버튼이 존재하지 않아서 bt_linktoblog이게 null인건 아닐 가능성이 높네요.

그렇다면 intent부분이라는겁니다.
...