2016-09-08 15 views
0

サーバに接続しようとしているときに問題が発生しました。 java.lang.NullPointerExceptionが: は、私はによって引き起こさヌルオブジェクト参照で仮想メソッド~ApplicationController.buildNetworkService(java.lang.String、int) 'を呼び出しようとしました

本当の問題が何であるかを知らないこのエラーメッセージフォームのlogcat を得た仮想メソッド「空org.androidtown.myjsgexample.ApplicationController.buildNetworkService(javaの起動を試みます.lang.String、INT)」org.androidtown.myjsgexample.MainActivity.onCreateにおけるNULLオブジェクト参照 (MainActivity.java:34)

public class ApplicationController extends Application{ 

    private static ApplicationController instance; 
    // 메소드 만들었네 getInstance 
    public static ApplicationController getInstance() { 
     return instance; 
    } 

    @Override 
    public void onCreate() { 
     super.onCreate(); 

     ApplicationController.instance = this; // 어플리케이션 처음 실행될때 instance생성 
    } 

    private NetworkService networkService; 
    public NetworkService getNetworkService(){ 
     return networkService; 
    } 

    private String baseUrl; 

    public void buildNetworkService(String ip, int port){ 
     synchronized (ApplicationController.class){ 

      if(networkService == null){ 
       baseUrl = String.format("http://simon-prac1.herokuapp.com/",ip, port); 
       Gson gson = new GsonBuilder().create(); 

       GsonConverterFactory factory = GsonConverterFactory.create(gson); 
       //서버에서 json형식으로 데이터를 보내고 이를 파싱해서 받아오기 위함 

       Retrofit retrofit = new Retrofit.Builder().baseUrl(baseUrl).addConverterFactory(factory).build(); 
       networkService = retrofit.create(NetworkService.class); 

      } 
     } 
    } 


} 

にこれはMainActivityのライン34の供給源です。

ApplicationController application = ApplicationController. getInstance(); 
    application.buildNetworkService("127.0.0.1",3306); 
    networkService = ApplicationController.getInstance().getNetworkService(); 

これはNetworkServiceインターフェイスです。

public interface NetworkService { 

    @POST("/PersonalData") 
    Call<PersonalData> post_personalData(@Body PersonalData personalData); 

/* 
    @GET("/PersonalData") 
    Call<List<PersonalData>> getAllData(); 
*/ 

    @GET("/PersonalData/{name}") 
    Call<PersonalData> getNamePersonalData(@Path("name")String name); 


} 

エラー内容

09-08 03:17:46.059 4244-4244/org.androidtown.myjsgexample E/AndroidRuntime: FATAL EXCEPTION: main 
Process: org.androidtown.myjsgexample, PID: 4244 
java.lang.RuntimeException: Unable to start activity ComponentInfo{org.androidtown.myjsgexample/org.androidtown.myjsgexample.MainActivity}: java.lang.NullPointerException: Attempt to invoke virtual method 'void org.androidtown.myjsgexample.ApplicationController.buildNetworkService(java.lang.String, int)' on a null object reference 
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2416) 
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2476) 
at android.app.ActivityThread.-wrap11(ActivityThread.java) 
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1344) 
at android.os.Handler.dispatchMessage(Handler.java:102) 
at android.os.Looper.loop(Looper.java:148) 
at android.app.ActivityThread.main(ActivityThread.java:5417) 
at java.lang.reflect.Method.invoke(Native Method) 
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726) 
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616) 
Caused by: java.lang.NullPointerException: Attempt to invoke virtual method 'void org.androidtown.myjsgexample.ApplicationController.buildNetworkService(java.lang.String, int)' on a null object reference 
at org.androidtown.myjsgexample.MainActivity.onCreate(MainActivity.java:34) 
at android.app.Activity.performCreate(Activity.java:6237) 
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1107) 
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2369) 
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2476)  
at android.app.ActivityThread.-wrap11(ActivityThread.java)  
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1344)  
at android.os.Handler.dispatchMessage(Handler.java:102)  
at android.os.Looper.loop(Looper.java:148)  
at android.app.ActivityThread.main(ActivityThread.java:5417)  
at java.lang.reflect.Method.invoke(Native Method)  
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726)  
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)  

私を助けてください!

+0

あなたはやってみてくださいでした 'プライベート静的ApplicationControllerにインスタンス=新しいApplicationControllerに();'の代わりに 'onCreate'上でそれを初期化するの? –

答えて

0

チェックapplication nullの場合

そして、あなたのCustomApplicationのエントリポイント(あなたのケースのためのApplicationControllerに)を使用したManifest.xmlを確認するには、