key在这里是你要查找的内容(文字列)。
举个例子
String str = "abcdef"String key = "cde"
int index = 1
这时
str.indexOf(key, index)就返回2。因为我们从"abcdef"的index=1(b的位置)开始找,找到了"cde","cde"在str中的index=2。
此时,我们要继续找到话就要从 str 的 index = 2 + 3 的地方开始找。
2代表的是 "cde"在str中的index
3代表的是"cde"的长度,也就是key.length()。
修改map的key但是不改变该key对应的value值,可以使用map.put("key2",map.remove("key1"))
比如:
map.put("key1","value1")--此时:key1--value1
map.put("key2",map.remove("key1"))--此时 :key2--value1
java 获取map中所有的key和value值
java.util.Iterator 对 collection 进行迭代的迭代器。
java.util.Iterator it = map.entrySet().iterator()
while(it.hasNext()){
java.util.Map.Entry entry = (java.util.Map.Entry)it.next()
entry.getKey() //返回对应的键
entry.getValue() //返回对应的值
}
以前遍历Map key-value比较习惯的方式是先获取Map中的所有key值,
然后根据key,依次从Map中去数据,基本方式如下:
Map<String,String>testData = new HashMap<String, String>()
Set<String> keys = testData.keySet()
for(String key :keys){
System.out.println(key+" "+testData.get(key))
}
上述其中是第一种方法,原来一直用上述方法主要是自己有点懒,有了一种方法后就觉得够用的了,今天看源码,发现还Map接口中还有一个Entry<K,V>的接口,对应的还有一个 Set<Map.Entry<K, V>>entrySet()方法。
也就是说其实Map中的每条key-value数据对应着一个Entry,这样的话遍历Map其实就是要取出每个Entry,也就有了第二种遍历方法:
Set<Entry<String, String>> entries = testData.entrySet()
for (Entry<String, String>entry : entries) {
System.out.println(entry.getKey()+":"+entry.getValue())
}
当少量的数据时,上述两种方法的效率是差不多的,当数据比较多时,第二种还是要比第一种快。
当然上述说的两种遍历针对的情况是遍历出key-value,如果是只想遍历key或value,大可不必用以上的方法了,Map中提供了Set<K>keySet()和Collection<V>values()。