您始终可以使用 SQLlite 数据库将值存储在表中。另一方面,如果您坚持将其保存在 Shared Preference 中,则可以使用 save a array in SharedPreference 并从中加载一个数组,如下所示:
public String[] loadArray(String arrayName) {
SharedPreferences prefs = getSharedPreferences("preferencename", 0);
int size = prefs.getInt(arrayName + "_size", 0);
String array[] = new String[size];
for(int i=0;i<size;i++)
array[i] = prefs.getString(arrayName + "_" + i, null);
return array;
}
public boolean saveArray(String[] array, String arrayName) {
SharedPreferences prefs = getSharedPreferences("preferencename", 0);
SharedPreferences.Editor editor = prefs.edit();
editor.putInt(arrayName +"_size", array.length);
for(int i=0;i<array.length;i++)
editor.putString(arrayName + "_" + i, array[i]);
return editor.commit();
}
因此,为了保存数组调用:
String [] alarmNames; // Load the array with values
saveArray(alarmNames, "nameOfAlarms");
String [] alarmIds; // Load the array with values
saveArray(alarmIds, "idOfAlarms");
String [] alarmSounds; // Load the array with values
saveArray(alarmSounds, "soundOfAlarms");
从共享首选项加载阵列
String [] arrName = loadArray("nameOfAlarms");
String [] arrID = loadArray("idOfAlarms");
String [] arrSound = loadArray("soundOfAlarms");
请参阅如何正确使用加载数组和保存数组方法?并将ArrayList 保存到 SharedPreferences以获取更多信息。
希望这可以帮助。