你是否已经对每次从Map中取得关键字然后再取得相应的值感觉厌倦?使用MapEntry类,你可以得到在同一时间得到所有的信息。
标准的Map访问方法如下:
Set
keys
=
mapkeySet(
);
if(keys
!=
null)
{
Iterator
iterator
=
keysiterator(
);
while(iteratorhasNext(
))
{
Object
key
=
iteratornext(
);
Object
value
=
mapget(key);
;…
;}
}
然后,这个方法有一个问题。从Map中取得关键字之后,我们必须每次重复返回到Map中取得相对的值,这是很繁琐和费时的。
幸运的是,这里有一个更加简单的途径。Map类提供了一个称为entrySet()的方法,这个方法返回一个MapEntry实例化后的对象集。
接着,MapEntry类提供了一个getKey()方法和一个getValue()方法,因此,上面的代码可以被组织得更符合逻辑。举例如下:
Set
entries
=
mapentrySet(
);
if(entries
!=
null)
{
Iterator
iterator
=
entriesiterator(
);
while(iteratorhasNext(
))
{
MapEntry
entry
=iteratornext(
);
Object
key
=
entrygetKey(
);
Object
value
=
entrygetValue();
;…
}
}
尽管增加了一行代码,我们却省略了许多对Map不必要的"get"调用。同时,提供给开发人员一个同时保持了关键字和其对应的值的类。MapEntry同时也提供了一个setValue()方法,程序员可以使用它修改map里面的值。
Hashtable内部排列的方式是散列排布,所以当输出信息时会是无序的。为了能保证输出的数据按照顺序排列,不要渴望用java自带的函数来对
Hashtable对象进行调整处理。当我们获取Hashtable里的KEY和VALUE时,一般都运行了MapEntry类来转换,好,现在就用这
个类来作文章,我具体写了一个方法。
代码:
/
方法名称:getSortedHashtable
参数:Hashtable
h
引入被处理的散列表
描述:将引入的hashtableentrySet进行排序,并返回
/
public
static
MapEntry[]
getSortedHashtable(Hashtable
h){
Set
set
=
hentrySet();
MapEntry[]
entries
=
(MapEntry[])settoArray(new
MapEntry[setsize()]);
Arrayssort(entries,new
Comparator(){
public
int
compare(Object
arg0,
Object
arg1)
{
Object
key1
=
((MapEntry)arg0)。getKey();
Object
key2
=
((MapEntry)arg1)。getKey();
return
((Comparable)key1)。compareTo(key2);
}
});
return
entries;
}
调用这个方法:
MapEntry[]
set
=
getSortedHashtable(t);
//perportyTable
for
(int
i=0;i<setlength;i++){
Systemoutprintln(set[i]getKey()。toString());
Systemoutprintln(set[i]getValue()。toString());
}
你是否已经对每次从Map中取得关键字然后再取得相应的值感觉厌倦?使用MapEntry类,你可以得到在同一时间得到所有的信息。
标准的Map访问方法如下:
Set
keys
=
mapkeySet(
);
if(keys
!=
null)
{
Iterator
iterator
=
keysiterator(
)
hashmap中key值是唯一的,但value是不唯一的 所以是没有办法通过像get(key)取value值一样直接取key的 如果你一定要这么做的话也可以,但是要注意同一个value可能返回多个key哦 写个例子给你:@Testpublic void test()
hm已是一个HashMap的引用。
如果你知道当前的这个key,可以通过hmget(key)方法来获得value。
获得key的方法hmkeySet();因为你不知道key是哪个其实该方法就是获得一个key的集合。
具体可以结合以下例子看看,里面有个迭代器用于遍历的。
Set<Integer> s=hmkeySet();//通过keySet方法可获得所有key的集合,放在一个容器Set里面。
Iterator<Integer> it=siterator();//获得一个迭代器引用it,通过siterator方法好比使“指针”指向
//set里面的第一个元素的位置
while(ithasNext())//set里面如果有下一个
{
Integer key=itnext();//返回当前set中的这个元素(因为set中都是放的key,“指针”指向下一个
Systemoutprintln(hmget(key));//利用hmget(key)方法获得该key对应的value
}
以上就是关于如何取出Map中key和value的值全部的内容,包括:如何取出Map中key和value的值、如何根据key取出map中的value值、如何能通过hashmap的某一value来返回其对应的键值key等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)