Java HashMap에 중복된 키 값 삽입
HashMap에 중복된 값을 삽입하려면 먼저 HashMap에 요소가 어떻게 저장되어 있는지 파악해야 합니다.
put 메소드
Map에 저장된 모든 요소는 키-값 쌍이며 모두 Put 메소드를 통해 추가되며 동일한 키는 Map에 하나의 관련 값만 존재합니다. Put 메소드는 Map에서 다음과 같이 정의됩니다.
V put(K key, V value);
put() 메소드 구현:
먼저 hash(key)는 키의 hashcode()를 가져옵니다. hashmap은 얻은 모든 hashcode를 기반으로 삽입할 위치가 있는 체인을 찾습니다. 항목 키-값 쌍은 이 체인을 찾은 후 삽입할 키-값 쌍이 이미 있는지 확인하기 위해 equals() 메서드를 사용하고 이는 실제로 키를 비교합니다.
키-값과 같은 키-값 쌍을 저장하는 데 사용됩니다. 반환 값은 맵에 저장된 키의 이전 값입니다. 이전에 존재하지 않으면 null이 반환됩니다. HashMap의 put 메소드는 다음과 같이 구현됩니다.
// 在此映射中关联指定值与指定键。如果该映射以前包含了一个该键的映射关系,则旧值被替换 public V put(K key, V value) { // 当key为null,调用putForNullKey方法,保存null与table第一个位置中,这是HashMap允许为null的原因 if (key == null) return putForNullKey(value); // 使用hash函数预处理hashCode,计算key的hash值 int hash = hash(key.hashCode());//-------(1) // 计算key hash 值在 table 数组中的位置 int i = indexFor(hash, table.length);//------(2) // 从i出开始迭代 e,找到 key 保存的位置 for (Entry<K, V> e = table[i]; e != null; e = e.next) { Object k; // 判断该条链上是否有hash值相同的(key相同) // 若存在相同,则直接覆盖value,返回旧value if (e.hash == hash && ((k = e.key) == key || key.equals(k))) { // 旧值 = 新值 V oldValue = e.value; // 将要存储的value存进去 e.value = value; e.recordAccess(this); // 返回旧的value return oldValue; } } // 修改次数增加1 modCount++; // 将key、value添加至i位置处 addEntry(hash, key, value, i); return null; }
위에서 해당 키-값 조합을 추가할 때 해당 키가 이미 존재하면 해당 값이 직접 변경되고 이전 값이 반환된다는 것을 알 수 있습니다. 먼저 키의 hashCode를 가져온 다음 같은지 비교합니다.
위 코드에서 바로 비교는 Map.Entry의 hashCode와 키의 hashCode에 해당합니다. 실제로 Map.Entry의 hashCode는 실제로 키의 hashCode입니다.
해당 키가 원래 존재하지 않는 경우 addEntry가 호출되어 해당 키-값을 맵에 추가합니다.
addEntry가 전달한 매개변수 hash는 해당 키의 hashCode입니다.
참조 객체의 키로서의 고유성 실현
put() 메소드에 대한 연구를 통해 키의 존재 여부를 판단할 때 먼저 키의 hashCode를 비교한 후 같음 또는 같음을 비교하고, 따라서 hashCode( ) 및 equals() 메소드를 다시 작성하면 키 참조(동일한 인스턴스 변수를 사용하여 객체를 가리킴)를 덮어쓸 수 있습니다.
class MyType { private String arga; private String argb; public MyType(String arga, String argb) { this.arga = arga; this.argb = argb; } @Override public int hashCode(){ return this.arga.hashCode() * this.argb.hashCode() ; } @Override public boolean equals(Object obj) { if (this == obj) { return true; } if (!(obj instanceof MyType)) { return false; } MyType p = (MyType) obj; if (this.arga.equals(p.arga) && this.argb.equals(p.argb)) { return true ; } else { return false ; } } }
이 두 메서드를 다시 작성한 후 중복된 참조 개체를 덮어쓸 수 있습니다. 값을 겹쳐야 하는 경우 put() 메서드를 호출하기 전에 containKey() 메서드를 사용하여 중복된 키 값이 있는지 확인하세요. 따라서 get () 메소드를 사용하여 원래 값을 얻고 새로 추가된 값을 추가합니다.
HashMap은 동일한 키 값 문제를 해결합니다
일부 시나리오에서는 여러 값에 대응하는 하나의 키 값이 필요하지만, 맵의 하나의 키 값은 하나의 값 값에만 대응합니다. 해시맵은 동일한 키 값을 갖기 때문에 두 번째는 put은 첫 번째 값을 덮어쓰므로 이 문제를 해결하려면 다음과 같이 목록을 사용하여
저장하세요.
List<Map<String, List<RecommendationListBO>>> hashList = new ArrayList<>(); Iterator<Map.Entry<String, List<RecommendationListBO>>> iterator = recommendationHashMap.entrySet().iterator(); Map.Entry<String, List<RecommendationListBO>> entry; while (iterator.hasNext()) { entry = iterator.next(); // 往newMap中放入新的Entry HashMap<String, List<RecommendationListBO>> newMap = new LinkedHashMap<>(); newMap.put(entry.getKey().split(",")[0], entry.getValue()); hashList.add(newMap); }
새 지도를 만들 때마다 지도 목록에 추가하세요. 아이디어는 대략 이렇습니다.
위 내용은 Java HashMap을 기반으로 중복 키 값 삽입 문제를 해결하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

hashmap的扩容机制是:重新计算容量,用一个新的数组替换原来的数组。重新计算原数组的所有数据并插入一个新数组,然后指向新数组;如果数组在容量扩展前已达到最大值,则直接将阈值设置为最大整数返回。

如何使用HashMap类的put()方法将键值对插入到HashMap中HashMap是Java集合框架中的一个非常重要的类,它提供了一种存储键值对的方式。在实际开发中,我们经常需要向HashMap中插入键值对,通过使用HashMap类的put()方法可以很轻松地实现这一目标。HashMap的put()方法的签名如下:Vput(Kkey,Vvalue)

1、说明Map基本上可以使用HashMap,但是HashMap有一个问题,那就是迭代HashMap的顺序不是HashMap放置的顺序,就是无序。HashMap的这个缺点往往会带来麻烦,因为有些场景我们期待一个有序的Map,这就是LinkedHashMap。2、区别实例publicstaticvoidmain(String[]args){Mapmap=newLinkedHashMap();map.put("apple","苹果");map.put("

Java文档解读:HashMap类的containsKey()方法用法详解,需要具体代码示例引言:HashMap是Java中常用的一种数据结构,它提供了高效的存储和查找功能。其中的containsKey()方法用于判断HashMap中是否包含指定的键。本文将详细解读HashMap类的containsKey()方法的使用方式,并提供具体的代码示例。一、cont

一、单例模式是什么?单例模式是一种对象创建模式,它用于产生一个对象的具体实例,它可以确保系统中一个类只产生一个实例。Java里面实现的单例是一个虚拟机的范围,因为装载类的功能是虚拟机的,所以一个虚拟机在通过自己的ClassLoad装载实现单例类的时候就会创建一个类的实例。在Java语言中,这样的行为能带来两大好处:1.对于频繁使用的对象,可以省略创建对象所花费的时间,这对于那些重量级对象而言,是非常可观的一笔系统开销;2.由于new操作的次数减少,因而对系统内存的使用频率也会降低,这将减轻GC压

JavaMap是Java标准库中常用的数据结构,它以键值对的形式存储数据。Map的性能对于应用程序的运行效率至关重要,如果Map的性能不佳,可能会导致应用程序运行缓慢,甚至崩溃。1.选择合适的Map实现Java提供了多种Map实现,包括HashMap、TreeMap和LinkedHashMap。每种Map实现都有其各自的优缺点,在选择Map实现时,需要根据应用程序的具体需求来选择合适的实现。HashMap:HashMap是最常用的Map实现,它使用哈希表来存储数据,具有较快的插入、删除和查找速度

Java使用HashMap类的putAll()函数将一个Map添加到另一个Map中Map是Java中常用的数据结构,用来表示键值对的集合。在Java的集合框架中,HashMap是一个常用的实现类。它提供了putAll()函数,用于将一个Map添加到另一个Map中,方便实现数据的合并和拷贝。本文将介绍putAll()函数的使用方法,并提供相应的代码示例。首先,

javaHashMap插入重复Key值要在HashMap中插入重复的值,首先需要弄清楚HashMap里面是怎么存放元素的。put方法Map里面存放的每一个元素都是key-value这样的键值对,而且都是通过put方法进行添加的,而且相同的key在Map中只会有一个与之关联的value存在。put方法在Map中的定义如下。Vput(Kkey,Vvalue);put()方法实现:首先hash(key)得到key的hashcode(),hashmap根据获得的hashcode找到要插入的位置所在的链,


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

DVWA
DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

PhpStorm 맥 버전
최신(2018.2.1) 전문 PHP 통합 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

MinGW - Windows용 미니멀리스트 GNU
이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

ZendStudio 13.5.1 맥
강력한 PHP 통합 개발 환경
