<?xml version="1.0" encoding="utf-8" standalone="yes"?><rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom"><channel><title>Data-Structures on Yonatan Karp-Rudin</title><link>https://yonatankarp.github.io/he/tags/data-structures/</link><description>Recent content in Data-Structures on Yonatan Karp-Rudin</description><generator>Hugo</generator><language>he</language><lastBuildDate>Fri, 02 Dec 2022 00:00:00 +0100</lastBuildDate><atom:link href="https://yonatankarp.github.io/he/tags/data-structures/index.xml" rel="self" type="application/rss+xml"/><item><title>איך HashMap עובד ב-Java?</title><link>https://yonatankarp.github.io/he/blog/how-hashmap-works-java/</link><pubDate>Fri, 02 Dec 2022 00:00:00 +0100</pubDate><guid>https://yonatankarp.github.io/he/blog/how-hashmap-works-java/</guid><description>&lt;p&gt;בתור מראיין, אני הרבה פעמים שואל על איך HashMap עובד ב-Java. זה עוזר לי להעריך את ההבנה של המועמד במבני נתונים, ב-JVM internals ובגישה שלהם לפתרון בעיות. נתקלתי בהרבה מועמדים — ג&amp;rsquo;וניורים, מידים וסניורים — שלא הצליחו לענות על השאלה הזו נכון. אז החלטתי לשתף את התשובה עם כולם.&lt;/p&gt;
&lt;p&gt;במאמר הזה אני אסביר את שאלת ה-HashMap צעד אחר צעד.&lt;/p&gt;
&lt;h3 id="מה-החוזה-בין-הפונקציות-equals-ו-hashcode-ב-java"&gt;מה החוזה בין הפונקציות &lt;code&gt;equals()&lt;/code&gt; ו-&lt;code&gt;hashCode()&lt;/code&gt; ב-Java?&lt;/h3&gt;
&lt;p&gt;&lt;img src="https://yonatankarp.github.io/images/blog/medium-1*o-EXRh62Vv1wF6hGc8enkg.jpeg" alt=""&gt;&lt;/p&gt;
&lt;p&gt;ב-Java, כל האובייקטים יורשים את הפונקציות &lt;code&gt;equals()&lt;/code&gt; ו-&lt;code&gt;hashCode()&lt;/code&gt; מקלאס &lt;code&gt;Object&lt;/code&gt;. לפי הדוקומנטציה של &lt;code&gt;equals()&lt;/code&gt;, יש צורך לעקוף גם את המתודה &lt;code&gt;hashCode()&lt;/code&gt;. זה מבטיח שאובייקטים שווים יהיו בעלי hash codes שווים.&lt;/p&gt;</description></item><item><title>איך לשבור HashMap בפחות מדקה</title><link>https://yonatankarp.github.io/he/blog/break-hashmap-less-than-a-minute/</link><pubDate>Fri, 02 Dec 2022 00:00:00 +0100</pubDate><guid>https://yonatankarp.github.io/he/blog/break-hashmap-less-than-a-minute/</guid><description>&lt;blockquote&gt;
&lt;p&gt;&lt;strong&gt;TL;DR:&lt;/strong&gt; אף פעם אל תשתמשו באובייקטים mutable כמפתחות ב-HashMap!&lt;/p&gt;
&lt;/blockquote&gt;
&lt;p&gt;אחרי שכתבתי את המאמר &lt;a href="https://yonatankarp.com/how-does-hashmap-work-in-java"&gt;&lt;strong&gt;How does HashMap work in Java?&lt;/strong&gt;&lt;/a&gt;, כמה אנשים הציעו נושאים נוספים הקשורים ל-HashMap. בגלל זה החלטתי ליצור סדרה קצרה של מאמרים על הנושא.&lt;/p&gt;
&lt;p&gt;במאמר של היום נדבר על JVM HashMaps ועל איך קל לשבור אותם אם לא משתמשים בהם בזהירות. חשוב לציין שלמרות שנתמקד בעולם ה-JVM, אותם עקרונות חלים על רוב שפות התכנות המודרניות.&lt;/p&gt;
&lt;p&gt;במאמר הזה אני אספק מימוש ב-Java ואסביר את שורש הבעיה. אני גם אציע פתרונות לבעיות שאני מציג.&lt;/p&gt;</description></item></channel></rss>