2014-09-06 2 views
3

Я хочу очистить все значения хэш-карты до того, как значения будут присвоены хэш-карте из db. Например, hashmap<string,string> demo - это моя хэш-карта, в которой я добавил следующие значения из db. Ответ результата от hashmap равен {A=1, B=2, C=3, D=4, E=5}. view load Я хочу вставить это в выше hashmap {A=test, B=demo, C=sample, D=empty, E=null}. Для этого как я могу очистить первые значения перед вставкой второго набора значений. И также я попытался использовать demo.clear(), он не работает. Как я могу очистить 1-й список значения перед добавлением второго. Попробуйте некоторые решения для решения проблемы.Как очистить хэш-карту <string, string> values?

Это код для извлечения данных из db.

public HashMap<String, String> getdata() { 
    try { 
     HashMap<String, String> map = new HashMap<String, String>(); 
     Log.e("getdata", "Started"); 
     String selectQuery = "SELECT * FROM tablename"; 
     SQLiteDatabase database = this.getWritableDatabase(); 
     Cursor cursor = database.rawQuery(selectQuery, null); 
     if (cursor.moveToFirst()) { 
      do { 
       map.put(cursor.getString(cursor.getColumnIndex("colmn1")), 
         cursor.getString(cursor.getColumnIndex("colmn2"))); 
      } while (cursor.moveToNext()); 
     } 
     cursor.close(); 
     return map; 

    } catch (Exception e) { 
     e.printStackTrace(); 
     Log.e("getdata", "Ended"); 
    } 
    return null; 

} 

В этой демо только реакция идет, как я объяснил above.And то делаю это

if(demo.isEmpty()) 
     { 
//code for correct condition 
     } 
else 
    { 
    demo.clear(); 
    } 

И передавая значения хэш-карту, таким образом.

demo = dbhelper.getdata(); 

И мой LogCat исключения:

09-06 12:48:53.656: W/dalvikvm(5071): threadid=1: thread exiting with uncaught exception (group=0x40fb0258) 
09-06 12:48:53.660: W/System.err(5071): java.lang.RuntimeException: Unable to start activity ComponentInfo{packagename/packagename.listdata}: java.lang.NullPointerException 
09-06 12:48:53.660: W/System.err(5071):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2077) 
09-06 12:48:53.660: W/System.err(5071):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2104) 
09-06 12:48:53.660: W/System.err(5071):  at android.app.ActivityThread.access$600(ActivityThread.java:134) 
09-06 12:48:53.660: W/System.err(5071):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1247) 
09-06 12:48:53.660: W/System.err(5071):  at android.os.Handler.dispatchMessage(Handler.java:99) 
09-06 12:48:53.660: W/System.err(5071):  at android.os.Looper.loop(Looper.java:154) 
09-06 12:48:53.660: W/System.err(5071):  at android.app.ActivityThread.main(ActivityThread.java:4624) 
09-06 12:48:53.661: W/System.err(5071):  at java.lang.reflect.Method.invokeNative(Native Method) 
09-06 12:48:53.661: W/System.err(5071):  at java.lang.reflect.Method.invoke(Method.java:511) 
09-06 12:48:53.661: W/System.err(5071):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:809) 
09-06 12:48:53.661: W/System.err(5071):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:576) 
09-06 12:48:53.661: W/System.err(5071):  at dalvik.system.NativeStart.main(Native Method) 
09-06 12:48:53.661: W/System.err(5071): Caused by: java.lang.NullPointerException 
09-06 12:48:53.661: W/System.err(5071):  at packagename.listdata.onCreate(listdata.java:231) 
09-06 12:48:53.661: W/System.err(5071):  at android.app.Activity.performCreate(Activity.java:4479) 
09-06 12:48:53.661: W/System.err(5071):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1050) 
09-06 12:48:53.661: W/System.err(5071):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2041) 
+2

«Я пробовал« demo.clear() «он не работает» - что значит «он не работает»? Покажите свой код, иначе будет очень сложно объяснить, почему он не работает в вашей программе. – Jesper

+0

demo.clear() должен работать так, как предполагается, –

+0

@Jesper «он не работает» означает, что он выбрасывает исключение нулевого указателя в том месте, где я использовал «demo.clear()». Поэтому только я упомянул что –

ответ

5

hMap.clear() всегда работал хорошо для меня.

Еще

hMap.put("A","test"); 

автоматически переопределить существующее значение ключа "A".

Если вы все еще хотите, чтобы очистить значения,

Вы можете использовать

hMap = new HashMap<String,String>(); 

, который будет инициализировать новый HashMap в hMap.

+0

Но почему claer не работает? На самом деле это вопрос ОП. –

+0

Это всегда сработало для меня. Возможно, вы ошибаетесь. Пожалуйста, покажите код. –

+0

Вы должны задать тот же вопрос OP :) –