如何取出Map中key和value的值

如何取出Map中key和value的值,第1张

你是否已经对每次从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等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/9715683.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-01
下一篇 2023-05-01

发表评论

登录后才能评论

评论列表(0条)

保存