在PreLoad中将批量数据输入SQLite时,SharedPreferences如何获取getFirstRun(false)?

时间:2018-03-31 07:59:40

标签: java android sqlite sharedpreferences preload

我的应用程序可以使用DatabaseHelper.java将文本中的批量数据插入SQLite扩展SQLiteOpenHelper和PreLoadActivity.java扩展AsyncTask(使用Progress Bar在后台加载数据)。但是每当我总是加载数据时打开我的应用程序就会出错。我在我的应用程序中使用SharedPreferences。

这是代码。

AppPreference.java

public class AppPreference {

    SharedPreferences prefs;
    Context context;

    public AppPreference(Context context) {
        prefs = PreferenceManager.getDefaultSharedPreferences(context);
        this.context = context;
    }

    public void setFirstRun(Boolean input) {
        SharedPreferences.Editor editor = prefs.edit();
        String key = context.getResources().getString(R.string.app_first_run);
        editor.putBoolean(key, input);
        editor.commit();
    }

    public Boolean getFirstRun() {
        String key = context.getResources().getString(R.string.app_first_run);
        return prefs.getBoolean(key, true);
    }
}

DatabaseHelper.java(代码段)

public class DatabaseHelper extends SQLiteOpenHelper {

    private static final String DATABASE_NAME = "kamus.db";
    private static final int DATABASE_VERSION = 1;
    private static final String LOG = "DatabaseHelper";
    private static SQLiteDatabase db;

    private static DatabaseHelper instance;
    private static Context context;

    @Override
    public void onCreate(SQLiteDatabase db) {
        db.execSQL(CREATE_TABLE_ENGLISH);
        db.execSQL(CREATE_TABLE_INDONESIA);
    }

    @Override
    public synchronized void close(){
        if (instance != null)
            db.close();
    }

    public void insertEnglish(ArrayList<EnglishIndonesiaModel> kamusEnglish) {
        db.beginTransaction();
        try {
            for (EnglishIndonesiaModel data : kamusEnglish) {
                Log.d("tag", "insert eng: " + data.getWord());
                insertDataEnglish(data.getWord(), data.getTranslate());
            }
            db.setTransactionSuccessful();
        } catch (Exception error) {
            Log.e("tag", "error " + error.getLocalizedMessage());
        } finally {
            db.endTransaction();
        }
    }

    public void insertIndonesia(ArrayList<IndonesiaEnglishModel> kamusIndonesia) {
        db.beginTransaction();
        try {
            for (IndonesiaEnglishModel data : kamusIndonesia) {
                Log.d("tag", "insert ina:  " + data.getKata());
                insertDataIndonesia(data.getKata(), data.getTerjemahan());
            }
            db.setTransactionSuccessful();
        } catch (Exception error) {
            Log.e("tag", "eror " + error.getLocalizedMessage());
        } finally {
            db.endTransaction();
        }
    }
}

PreLoadActivity.java(代码段)

public class PreloadActivity extends AppCompatActivity {

    ProgressBar progressBar;
    TextView tvLoading;

    private DatabaseHelper databaseHelper;

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

        progressBar = findViewById(R.id.progress_bar);
        tvLoading = findViewById(R.id.tv_loading);

        databaseHelper = DatabaseHelper.getInstance(PreloadActivity.this);
        new LoadData().execute();
    }

private class LoadData extends AsyncTask<Void, Integer, String> {
        final String TAG = LoadData.class.getSimpleName();
        AppPreference appPreference;
        double progress;
        double maxProgress = 100;

 @Override
        protected void onPreExecute() {
            Log.d(TAG, "onpre");
            appPreference = new AppPreference(PreloadActivity.this);
        }

        @Override
        protected String doInBackground(Void... params) {

            Log.d(TAG, "doinbackground");

            ArrayList<EnglishIndonesiaModel> kamusEnglish = preLoadEnglishRaw(R.raw.english_indonesia);
            ArrayList<IndonesiaEnglishModel> kamusIndonesia = preLoadRaw(R.raw.indonesia_english);

            databaseHelper.insertEnglish(kamusEnglish);
            databaseHelper.insertIndonesia(kamusIndonesia);

            Boolean firstRun = appPreference.getFirstRun();
            if (firstRun) {

                Log.d("tag", "eng_ind size " + kamusEnglish.size());
                Log.d("tag", "ind_eng size " + kamusIndonesia.size());

                progress = 30;
                publishProgress((int) progress);
                Double progressMaxInsert = 100.0;
                Double progressDiff = (progressMaxInsert - progress) / kamusEnglish.size() + kamusIndonesia.size();

                // When DatabaseHelper.close() or insert Data SQLiteDatabase endTransaction() or setTransactionSuccessfull() then AppPreference.setFirstRun(false)
                ...................
                ...................
                ...................

                appPreference.setFirstRun(false);

                progress += progressDiff;
                publishProgress((int) maxProgress);

            } else {
                tvLoading.setVisibility(View.VISIBLE);
                try {
                    synchronized (this) {
                        this.wait(2000);
                        publishProgress(50);

                        this.wait(2000);
                        publishProgress((int) maxProgress);
                    }
                } catch (Exception e) {
                }
            }

            return "data inserted";
        }
    }
}

3 个答案:

答案 0 :(得分:0)

你在检查条件时搞砸了。 如果firstRun已完成,则根本不要致电AsyncTask

AppPreference appPreference = new AppPreference(PreloadActivity.this);
Boolean firstRun = appPreference.getFirstRun();
    if(firstRun) {
        new LoadData().execute();
 }

doInBackground()内设置setFirstRun(false)

appPreference.setFirstRun(false);

答案 1 :(得分:0)

public SharedPreferences pref;
public SharedPreferences.Editor editor;
private final String myPreference = "login";
private String firstTime = "firstTime";

public Method(Activity activity) {
    this.activity = activity;
    pref = activity.getSharedPreferences(myPreference, 0); // 0 - for private mode
    editor = pref.edit();
}

if (!pref.getBoolean(firstTime, false)) {
      editor.putBoolean(firstTime, true);
      editor.commit();
}

you can get value pref.getBoolean(firstTime, false) // retun true allways

if(pref.getBoolean(firstTime, false)){
//your code
}

答案 2 :(得分:0)

更改您的AppPreference代码:

prefs= context.getSharedPreferences(your_preference_name, Context.MODE_PRIVATE);