java中的map里的value 怎么修改

java中的map里的value 怎么修改,第1张

重新put就可以,前提是你知道key

Map<String, String> map = new HashMap<String, String>();

mapput("key", "123456789");

Systemoutprintln("第一次赋值="+mapget("key"));

mapput("key", "ABCDEFGHIJK");

Systemoutprintln("第二次赋值="+mapget("key"));

第一次赋值=123456789

第二次赋值=ABCDEFGHIJK

map集合没有专门更改value的方法,更改value的方法就是mapput(key,value),更改就是直接替换,比如想改变key是"1",value是"一"的组合,就是mapput("1","壹"),直接替换就行。

import javautilHashMap;

public class Demo {

public static void main(String[] args) {

HashMap<String, Integer> map = new HashMap<String, Integer>();

mapput("张三", 89);

mapput("赵四", 100);

Systemoutprintln(map);

if (mapcontainsKey("张三")) {//判断如果存在 key ,就修改value

mapput("张三", 98);//修改

}

Systemoutprintln("------分割线------");

Systemoutprintln(map);

}

avaMap集合

Map集合没有继承Collection接口,,Map中不能包含相同的key值,每个key只能影射一个相同的value。key值还决定了存储对象在映射中的存储位置。

但不是key对象本身决定的,而是通过散列技术进行处理,可产生一个散列码的整数值,散列码通常用作一个偏移量,该偏移量对应分配给映射的内存区域的起始位置,从而确定存储对象在映射中的存储位置。Map集合包括Map接口以及Map接口所实现的类。

百度百科-JavaMap集合

//不说废话直接上代码

public static void main(String[] args)  

    {  

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

        cityMapput("广东","广州,深圳,潮州,湛江");

        cityMapput("河北", "石家庄,唐山,秦皇岛");

        cityMapput("广西", "桂林,南宁,柳州");

        

        Systemoutprintln("广东省:"+cityMapget("广东"));

        Systemoutprintln("河北省:"+cityMapget("河北"));

        Systemoutprintln("广西省:"+cityMapget("广西"));

    }

获取map的key和value的方法分为以下两种形式:

1、mapkeySet():先获取map的key,然后根据key获取对应的value;

2、mapentrySet():同时查询map的key和value,只需要查询一次;

注意:当map的value值相等时,根据key值进行排序

很多人都推荐使用entrySet,认为其比keySet的效率高很多。理由是:entrySet方法一次拿到所有key和value的集合;而keySet拿到的只是key的集合,针对每个key,都要去Map中额外查找一次value,从而降低了总体效率。

两种方法对比测试如下:

HashMap测试数据:

TreeMap测试数据:

扩展资料:

mapkeySet()和mapEntrySet()的比较:

一、如果使用HashMap

1、同时遍历key和value时,keySet与entrySet方法的性能差异取决于key的具体情况,如复杂度(复杂对象)、离散度、冲突率等。换言之,取决于HashMap查找value的开销。

entrySet一次性取出所有key和value的 *** 作是有性能开销的,当这个损失小于HashMap查找value的开销时,entrySet的性能优势就会体现出来。

在比测试中,当key是最简单的数值字符串时,keySet可能反而会更高效,耗时比entrySet少10%。总体来说还是推荐使用entrySet。

因为当key很简单时,其性能或许会略低于keySet,但却是可控的;而随着key的复杂化,entrySet的优势将会明显体现出来。当然,我们可以根据实际情况进行选择

2、只遍历key时,keySet方法更为合适,因为entrySet将无用的value也给取出来了,浪费了性能和空间。在上述测试结果中,keySet比entrySet方法耗时少23%。

3、只遍历value时,使用vlaues方法是最佳选择,entrySet会略好于keySet方法。

二、如果使用TreeMap

1、同时遍历key和value时,与HashMap不同,entrySet的性能远远高于keySet。这是由TreeMap的查询效率决定的,也就是说,TreeMap查找value的开销较大,明显高于entrySet一次性取出所有key和value的开销。因此,遍历TreeMap时强烈推荐使用entrySet方法。

2、只遍历key时,keySet方法更为合适,因为entrySet将无用的value也给取出来了,浪费了性能和空间。在上述测试结果中,keySet比entrySet方法耗时少24%。

3、只遍历value时,使用vlaues方法是最佳选择,entrySet也明显优于keySet方法。

参考资料:

百度百科——Map

mapput("123",

new

float[]{11,

11,

11});

按照你已有的代码,存进去的时候,new一个float数组,直接传值就可以了

实现思路:先排序,之后取出最大的一个即可。<pre t="code" l="java">import javautilArrays;

import javautilCollection;

import javautilHashMap;

import javautilMap;

import javautilSet;

public class MaxMapDemo {

public static void main(String[] args) {

Map<Integer, Integer> map = new HashMap<Integer, Integer>();

mapput(1, 8);

mapput(3, 12);

mapput(5, 53);

mapput(123, 33);

mapput(42, 11);

mapput(44, 42);

mapput(15, 3);

Systemoutprintln(getMaxKey(map));

Systemoutprintln(getMaxValue(map));

}

/

求Map<K,V>中Key(键)的最大值

@param map

@return

/

public static Object getMaxKey(Map<Integer, Integer> map) {

if (map == null) return null;

Set<Integer> set = mapkeySet();

Object[] obj = settoArray();

Arrayssort(obj);

return obj[objsize()-1];

}

/

求Map<K,V>中Value(值)的最大值

@param map

@return

/

public static Object getMaxValue(Map<Integer, Integer> map) {

if (map == null) return null;

Collection<Integer> c = mapvalues();

Object[] obj = ctoArray();

Arrayssort(obj);

return obj[objsize()-1];

}

}

Map是成对放的,一放一对。。分成KEY和VALUE

Map分为HashMap或Hashtable、LinkedHashMap和TreeMap几个,

其中HashMap是新版的,线程不安全的,Hashtable是线程安全的。

Map是一种把键对象和值对象进行关联的容器,而一个值对象又可以是一个Map,依次类推,这样就可形成一个多级映射。对于键对象来说,像Set一样,一个Map容器中的键对象不允许重复,这是为了保持查找结果的一致性;如果有两个键对象一样,那你想得到那个键对象所对应的值对象时就有问题了,可能你得到的并不是你想的那个值对象,结果会造成混乱,所以键的唯一性很重要,也是符合集合的性质的。当然在使用过程中,某个键所对应的值对象可能会发生变化,这时会按照最后一次修改的值对象与键对应。对于值对象则没有唯一性的要求。你可以将任意多个键都映射到一个值对象上,这不会发生任何问题(不过对你的使用却可能会造成不便,你不知道你得到的到底是那一个键所对应的值对象)。Map有两种比较常用的实现:HashMap和TreeMap。HashMap也用到了哈希码的算法,以便快速查找一个键,TreeMap则是对键按序存放,因此它便有一些扩展的方法,比如firstKey(),lastKey()等,你还可以从TreeMap中指定一个范围以取得其子Map。键和值的关联很简单,用put(Object

key,Object

value)方法即可将一个键与一个值对象相关联。用get(Object

key)可得到与此key对象所对应的值对象。

import

javautil;

class

HashMapDemo

{

public

static

void

main(String

args[])

{

//

Create

a

hash

map

HashMap

hm

=

new

HashMap();

//

Put

elements

to

the

map

hmput("John

Doe",

new

Double(343434));

hmput("Tom

Smith",

new

Double(12322));

hmput("Jane

Baker",

new

Double(137800));

hmput("Todd

Hall",

new

Double(9922));

hmput("Ralph

Smith",

new

Double(-1908));

//

Get

a

set

of

the

entries

Set

set

=

hmentrySet();

//

Get

an

iterator

Iterator

i

=

setiterator();

//

Display

elements

while(ihasNext())

{

MapEntry

me

=

(MapEntry)inext();

Systemoutprint(megetKey()

+

":

");

Systemoutprintln(megetValue());

}

}

由MapEntry定义的getKey(

)和getValue(

)方法而显示。程序开始创建一个散列映射,然后将名字的映射增加到平衡表中。接下来,映射的内容通过使用由调用函数entrySet(

)而获得的集合“视图”而显示出来。关键字和值通过调用

以上就是关于java中的map里的value 怎么修改全部的内容,包括:java中的map里的value 怎么修改、在java的Map集合中,怎样更改value的值、用java中如何用Hashmap,通过输入Key输出对应的value等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

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

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

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

发表评论

登录后才能评论

评论列表(0条)

保存