ContentValues
ContentValues 和HashTable類似都是一種存儲的機制 但是兩者最大的區(qū)別就在于蜜葱,contenvalues Key只能是String類型,values只能存儲基本類型的數(shù)據(jù),像string,int之類的,不能存儲對象這種東西散址。ContentValues 常用在數(shù)據(jù)庫中的操作。
在往數(shù)據(jù)庫中插入數(shù)據(jù)的時候锈玉,首先應(yīng)該有一個ContentValues的對象所以:
ContentValues initialValues = new ContentValues();
initialValues.put(key,values);
SQLiteDataBase sdb ;
sdb.insert(database_name,null,initialValues);
HashMap和HashTable
HashMap不是線程安全的爪飘,HashTable是線程安全的一個Collection义起。HashMap允許將null作為一個entry的key或者value拉背,而Hashtable不允許。
hastmap是一個接口 是map接口的子接口默终,是將鍵映射到值的對象椅棺,其中鍵和值都是對象犁罩,并且不能包含重復(fù)鍵,但可以包含重復(fù)值两疚。HashMap允許null key和null value床估,而hashtable不允許。
HashMap是Hashtable的輕量級實現(xiàn)(非線程安全的實現(xiàn))诱渤,他們都完成了Map接口丐巫,主要區(qū)別在于HashMap允許空(null)鍵值(key),由于非線程安全,效率上可能高于Hashtable勺美。HashMap允許將null作為一個entry的key或者value递胧,而Hashtable不允許。
HashMap把Hashtable的contains方法去掉了赡茸,改成containsvalue和containsKey缎脾。因為contains方法容易讓人引起誤解。
Hashtable繼承自Dictionary類占卧,而HashMap是Java1.2引進的Map interface的一個實現(xiàn)遗菠。
最大的不同是,Hashtable的方法是Synchronize的华蜒,而HashMap不是辙纬,在多個線程訪問Hashtable時,不需要自己為它的方法實現(xiàn)同步叭喜,而HashMap 就必須為之提供外同步牲平。
Hashtable和HashMap采用的hash/rehash算法都大概一樣,所以性能不會有很大的差異域滥。