重新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等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)