2014-09-06 27 views
3

我想清除所有哈希映射值,然后将值分配给db的哈希映射。例如,hashmap<string,string> demo是我的哈希映射,因为我已经从db添加了以下值。哈希映射的结果响应是{A=1, B=2, C=3, D=4, E=5}。查看加载我想在上面的hashmap中插入这个{A=test, B=demo, C=sample, D=empty, E=null}。对于这个问题,我怎样才能在插入第二组值之前清除第一个值。并且我也尝试过使用demo.clear()它不工作。如何清除第一个列表值之前添加第二个。建议一些解决方案来解决问题。如何清除哈希映射<string,string>值?

这是从数据库中检索数据的代码。

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 2014-09-06 07:00:33

+0

demo.clear()应该按照它应该的方式工作 – 2014-09-06 07:01:00

+0

@Jesper“它不工作”意味着它在我使用“demo.clear()”的地方抛出空指针异常,所以只有我提到过那 – 2014-09-06 07:06:30

回答

5

hMap.clear()总是为我工作得很好。

不过

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

将自动覆盖关键 “A” 现有的值。

如果你仍然想清除值,

您可以使用

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

将在hMap初始化一个新的HashMap中。

+0

但为什么claer不工作?这实际上是OP的问题。 – 2014-09-06 07:04:04

+0

它总是为我工作。你可能会犯一些错误。请显示代码。 – 2014-09-06 07:04:53

+0

您必须向OP询问相同的问题:) – 2014-09-06 07:05:36