0

ボタンの insideOnclick メソッドでローダーを初期化していますが、失敗し、「null」を渡すときに最後の 3 番目のパラメーターが原因でエラーが発生し、 「this」を渡すときにエラーが発生し、 作業も失敗しました。

    loginBtn.setOnClickListener(new View.OnClickListener() {
                @Override
            public void onClick(View arg0) {
                    if(userName.getText().length() == 0 || password.getText().length() == 0)
                {
            Toast.makeText(context,"UserName Or Password Should be Filled",Toast.LENGTH_SHORT).show();
            }
        else{
    userName.setText("");
   password.setText("");
   **getLoaderManager().initLoader(1,null,null);** //here is the error 

                    }
                }
                });

            }
             @Override
                public  Loader<User> onCreateLoader(int id,Bundle args) {
                 loginLoader = new LoginLoader(context,userName.getText().toString(),password.getText().toString(),"2013-07-10 01:18:26");
                Log.i("login loader",""+loginLoader);
                 return loginLoader;
                 }

                @Override
                public void onLoadFinished(Loader<User> arg0,User proposals) {
                    Log.i("User",""+proposals.getUsername());
                    }

エラーリストは次のとおりです。

01-27 23:27:33.480: E/AndroidRuntime(7777): 致命的な例外: メイン 01-27 23:27:33.480: E/AndroidRuntime(7777): java.lang.NullPointerException 01-27 23:27:33.480: E/AndroidRuntime(7777): android.app.LoaderManagerImpl.createLoader(LoaderManager.java:544) 01-27 23:27:33.480: E/AndroidRuntime(7777): android.app.LoaderManagerImpl.createAndInstallLoader(LoaderManager.java) :553) 01-27 23:27:33.480: E/AndroidRuntime(7777): android.app.LoaderManagerImpl.initLoader(LoaderManager.java:607) 01-27 23:27:33.480: E/AndroidRuntime(7777): com.mrfs.android.surveyapp.activities.LoginActivityService$1.onClick(LoginActivityService.java:58) 01-27 23:27:33.480: E/AndroidRuntime(7777): android.view.View.performClick(View.java) :4211) 01-27 23:27:33.480: E/AndroidRuntime(7777): android.view.View$PerformClick.run(View.java:17267) 01-27 23:27:33.480: E/AndroidRuntime(7777): android.os.Handler.handleCallback(Handler.java:615) 01-27 23:27:33.480: E/AndroidRuntime(7777) : android.os.Handler.dispatchMessage(Handler.java:92) 01-27 23:27:33.480: E/AndroidRuntime(7777): android.os.Looper.loop(Looper.java:137) 01-27 23:27:33.480: E/AndroidRuntime(7777): android.app.ActivityThread.main(ActivityThread.java:4898) 01-27 23:27:33.480: E/AndroidRuntime(7777): java.lang.reflect で.Method.invokeNative(ネイティブ メソッド) 01-27 23:27:33.480: E/AndroidRuntime(7777): java.lang.reflect.Method.invoke(Method.java:511) 01-27 23:27:33.480: E/AndroidRuntime(7777): com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1006) 01-27 23:27:33.480: E/AndroidRuntime(7777): com.android.internal で.os.ZygoteInit.メイン (ZygoteInit.java:773) 01-27 23:27:33.480: E/AndroidRuntime (7777): dalvik.system.NativeStart.main (ネイティブ メソッド) で *編集コード: LOGIN LIST SERVICE.JAVA *

public class LoginListService 
{
SurveyDBHelper surveyDBHelper;
private final  static  LoginListService INSTANCE = new LoginListService();
public LoginListService()
{}
public static LoginListService getLoginInstance()
{return INSTANCE;
}
public User getLoginResult(String userName, String password,
            String apkVersion) {
        MultiValueMap<String, Object> formData = new LinkedMultiValueMap<String, Object>();
        formData.add("username", "kong");
        formData.add("password", "kongkong");
        formData.add("apkStatusDate", "2013-07-10 01:18:26"); // **HERE IS THE ERROR** 
        System.out.print("form data values:" + formData);
        HttpEntity<MultiValueMap<String, Object>> requestEntity = new HttpEntity<MultiValueMap<String, Object>>(
                formData, WorkflowRestService.getInstance().getRequestHeaders());
        ResponseEntity<UserListItemHolder> responseEntity = WorkflowRestService
                .getInstance()
                .getRestTemplate()
                .exchange(WorkflowApp.getServicesURL() + "user/logIn",
                        HttpMethod.POST, requestEntity,
                        UserListItemHolder.class);

        Log.i("response Entity Login", "" + responseEntity);
        UserListItemHolder userListItemInstance = responseEntity.getBody();
        Log.i("response Entity Body Location Function",
                "" + responseEntity.getBody());
        if ("true".equals(userListItemInstance.getApkStatus())) {
Log.i("locationInstance.getLocationListItems if", ""+ userListItemInstance.getUserListItems());
            return userListItemInstance.getUserListItems();


        } else {
Log.i("locationInstance.getLocationListItems else", ""+ userListItemInstance.getUserListItems());
            userListItemInstance = null;
            return userListItemInstance.getUserListItems();
        }

    }
4

2 に答える 2

1

コードとマーカーを見ると、必須パラメーターの代わりにNullPointerExceptiona を渡しているために発生します。null

getLoaderManager().initLoader(1,null,null); //here is the error

LoaderManager Docsによると、コールバックが必要です。

パラメーター

  • idこのローダーの一意の識別子。好きなようにできます。識別子は、特定の LoaderManager インスタンスに再スコープされます。
  • args 構築時にローダーに提供するオプションの引数。ローダーが既に存在する場合 (新しいローダーを作成する必要はありません)、このパラメーターは無視され、最後の引数が引き続き使用されます。
  • ローダーの状態の変化について報告するために LoaderManager が呼び出すcallbackインターフェース。必須

すでに LoaderCallbacks を実装しているようです。実装をinitLoaderメソッドに渡すだけです。

getLoaderManager().initLoader(1,null,this);
于 2014-01-27T08:34:03.683 に答える