<?xml version="1.0" encoding="utf-8" standalone="yes"?><rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom"><channel><title>集合框架 on Weiming's Blog</title><link>https://axerzone.cn/tags/%E9%9B%86%E5%90%88%E6%A1%86%E6%9E%B6/</link><description>Recent content in 集合框架 on Weiming's Blog</description><generator>Hugo -- gohugo.io</generator><language>zh-cn</language><copyright>© 2026 Weiming</copyright><lastBuildDate>Sun, 20 Nov 2022 00:00:00 +0000</lastBuildDate><atom:link href="https://axerzone.cn/tags/%E9%9B%86%E5%90%88%E6%A1%86%E6%9E%B6/index.xml" rel="self" type="application/rss+xml"/><item><title>ConcurrentHashMap 线程安全原理</title><link>https://axerzone.cn/posts/concurrenthashmap-deep-dive/</link><pubDate>Sun, 20 Nov 2022 00:00:00 +0000</pubDate><guid>https://axerzone.cn/posts/concurrenthashmap-deep-dive/</guid><description>&lt;h1 class="relative group"&gt;ConcurrentHashMap 到底怎么保证线程安全的
 &lt;div id="concurrenthashmap-到底怎么保证线程安全的" class="anchor"&gt;&lt;/div&gt;
 
 &lt;span
 class="absolute top-0 w-6 transition-opacity opacity-0 -start-6 not-prose group-hover:opacity-100 select-none"&gt;
 &lt;a class="text-primary-300 dark:text-neutral-700 !no-underline" href="#concurrenthashmap-%e5%88%b0%e5%ba%95%e6%80%8e%e4%b9%88%e4%bf%9d%e8%af%81%e7%ba%bf%e7%a8%8b%e5%ae%89%e5%85%a8%e7%9a%84" aria-label="锚点"&gt;#&lt;/a&gt;
 &lt;/span&gt;
 
&lt;/h1&gt;
&lt;p&gt;上篇写了 HashMap，有同学私信问我 ConcurrentHashMap 和 HashMap 有什么区别。其实吧，区别大了去了，JDK8 的 ConcurrentHashMap 基本是重写的，跟 JDK7 完全两个思路。&lt;/p&gt;
&lt;p&gt;花了差不多一周把源码理清楚，这篇来聊聊它到底怎么在并发场景下保证线程安全。&lt;/p&gt;

&lt;h2 class="relative group"&gt;JDK7 的 Segment 分段锁
 &lt;div id="jdk7-的-segment-分段锁" class="anchor"&gt;&lt;/div&gt;
 
 &lt;span
 class="absolute top-0 w-6 transition-opacity opacity-0 -start-6 not-prose group-hover:opacity-100 select-none"&gt;
 &lt;a class="text-primary-300 dark:text-neutral-700 !no-underline" href="#jdk7-%e7%9a%84-segment-%e5%88%86%e6%ae%b5%e9%94%81" aria-label="锚点"&gt;#&lt;/a&gt;
 &lt;/span&gt;
 
&lt;/h2&gt;
&lt;p&gt;先说 JDK7 的方案，面试还是会问。&lt;/p&gt;</description></item><item><title>HashMap 源码笔记</title><link>https://axerzone.cn/posts/hashmap-source-code/</link><pubDate>Thu, 15 Sep 2022 00:00:00 +0000</pubDate><guid>https://axerzone.cn/posts/hashmap-source-code/</guid><description>&lt;h1 class="relative group"&gt;HashMap 源码我读了三遍才看懂
 &lt;div id="hashmap-源码我读了三遍才看懂" class="anchor"&gt;&lt;/div&gt;
 
 &lt;span
 class="absolute top-0 w-6 transition-opacity opacity-0 -start-6 not-prose group-hover:opacity-100 select-none"&gt;
 &lt;a class="text-primary-300 dark:text-neutral-700 !no-underline" href="#hashmap-%e6%ba%90%e7%a0%81%e6%88%91%e8%af%bb%e4%ba%86%e4%b8%89%e9%81%8d%e6%89%8d%e7%9c%8b%e6%87%82" aria-label="锚点"&gt;#&lt;/a&gt;
 &lt;/span&gt;
 
&lt;/h1&gt;
&lt;p&gt;大二下学期面试实习的时候，面试官问我 HashMap 的底层原理，我支支吾吾说了个&amp;quot;数组加链表&amp;quot;就说不下去了。回来之后就下定决心要把源码读一遍。结果读了三遍才算真正搞明白，这玩意比我想象的要精妙得多。&lt;/p&gt;
&lt;p&gt;&lt;figure&gt;&lt;img
 class="my-0 rounded-md"
 loading="lazy"
 decoding="async"
 fetchpriority="low"
 alt="Hash Table 示意图"
 src="https://upload.wikimedia.org/wikipedia/commons/thumb/5/5e/Hash_table_5_0_1_1_1_1_0_SP.svg/380px-Hash_table_5_0_1_1_1_1_0_SP.svg.png"
 &gt;&lt;/figure&gt;
&lt;/p&gt;

&lt;h2 class="relative group"&gt;先说说 HashMap 的内部结构
 &lt;div id="先说说-hashmap-的内部结构" class="anchor"&gt;&lt;/div&gt;
 
 &lt;span
 class="absolute top-0 w-6 transition-opacity opacity-0 -start-6 not-prose group-hover:opacity-100 select-none"&gt;
 &lt;a class="text-primary-300 dark:text-neutral-700 !no-underline" href="#%e5%85%88%e8%af%b4%e8%af%b4-hashmap-%e7%9a%84%e5%86%85%e9%83%a8%e7%bb%93%e6%9e%84" aria-label="锚点"&gt;#&lt;/a&gt;
 &lt;/span&gt;
 
&lt;/h2&gt;
&lt;p&gt;你打开 HashMap 的源码，会看到一个叫 &lt;code&gt;Node&amp;lt;K,V&amp;gt;[] table&lt;/code&gt; 的数组。这就是 HashMap 的骨架。&lt;/p&gt;</description></item></channel></rss>