我有一个应用程序,需要在各种片段和活动中输入大量用户。现在我将所有变量放在一个类中,然后调用它" Report"我绕过主键确切地知道"报告"我在。(在开始时有一个ListView,用户选择他们想要更改的报告) 由于最终必须将所有用户输入写入数据库,我有一个想法 - 为什么不从报告中删除所有变量并用静态最终列名替换它们,只留下主键变量,然后使用getter和setter来直接读取和写入数据库?这是一个很好的设计使用还是有任何我缺少的缺点? 作为一个相对缺乏经验的Android开发人员,我要求我提出任何建议。
示例(对不起,如果我从手机上写这个错误的话):
public class Report {
private int primaryKey;
private SQLiteDBHelper db;
private static final String ColumnA = "columnA";
private static final String ColumnB = "columnB";
private static final String ColumnC = "columnC";
// lets say columns A and B are Strings and C is an int
public Report(int primaryKey, Context ctx) {
this.primaryKey = primaryKey;
this.db = new SQLiteDBHelper(ctx);
}
public String getColumnA() {
return db.getString(primaryKey, ColumnA)
}
public boolean setColumnA(String value) {
return db.setString(primaryKey, ColumnA, value);
}
public String getColumnB() {
return db.getString(primaryKey, ColumnB)
}
public boolean setColumnB(String value) {
return db.setString(primaryKey, ColumnB, value);
}
public String getColumnC() {
return String.valueOf(db.getInt(primaryKey, ColumnC));
}
public boolean setColumnC(String value) {
return db.setInt(primaryKey, ColumnC, Helper.tryParseInt(value));
}
}
然后我可以像这样扩展TextWatcher:
public MyTextWatcher extends TextWatcher {
private View view;
private Report report;
public MyTextWatcher(View view, Report report) {
this.view = view;
this.report = report;
}
public void afterTextChanged(Editable editable) {
String input = editable.toString();
switch(view.getId()) {
case R.id.columnA:
if (!report.setColumnA(input)) {
// something went wrong
}
... etc.
}
}
在活动/片段中,我会这样做
int primaryKey = get from shared pref;
Report report = new Report(primaryKey, getApplication());
EditText columnA = (EditText) v.findViewById(R.id.columnA);
EditText columnB = (EditText) v.findViewById(R.id.columnB);
columnA.setText(report.getColumnA());
columnB.setText(report.getColumnB());
columnA.addTextChangedListener(new MyTextWatcher(columnA, report));
columnB.addTextChangedListener(new MyTextWatcher(columnB, report));
为什么我认为这是一个好主意:
我可以在SharedPreferences中保存当前的primaryKey(从ListView中选择的一个用户),然后在我需要使用它的每个活动/片段中从中创建一个新报告,而不会占用太多内存
我可以确保用户输入的内容与数据库中的内容之间不存在任何差异 - 例如,在EditTexts上,我可以为OnTextChanged侦听器中的每一列调用相应的setter
对于每个活动/片段,只有在onCreate
更少的代码? (比如我在DB帮助器中只需要get / setInt和get / setString方法,我不需要在活动/片段之间传递任何东西,只需要一个TextWatcher类)
为什么我认为这种做法可能不好:
不断读取和写入数据库 - 电池使用情况和速度可能有问题吗?
???
答案 0 :(得分:1)
目前你是:
每次文本更改时写入数据库 - 就像用户一样 键入每个字符或删除字符,记录正在 保存。这甚至不等待用户完成,这太过分了 保存文字。更好的选择是等到用户移动 到另一个小部件 - 暗示他已完成EditText上的输入。 您可以使用OnFocusChangeListener(更多信息: How can i know when a edittext lost focus)
在UI线程上对数据库进行大量写入调用。你
如果可能的话,应该将其委托给后台。
当用户主动与应用互动时,Android不会终止前台进程。您不必担心数据丢失。如果需要,您可以等待应用暂停。