当前位置: 首页 > news >正文

傻瓜式网站建设网站关键词优化多少钱

傻瓜式网站建设,网站关键词优化多少钱,济南网站制作推广,烟台H5网站设计公司Java Map实现类面试题 HashMap Q1: HashMap的实现原理是什么? HashMap基于哈希表实现,使用数组链表红黑树(Java 8)的数据结构。 public class HashMapPrincipleExample {// 模拟HashMap的基本结构public class SimpleHashMap&…

Java Map实现类面试题

HashMap

Q1: HashMap的实现原理是什么?

HashMap基于哈希表实现,使用数组+链表+红黑树(Java 8)的数据结构。

public class HashMapPrincipleExample {// 模拟HashMap的基本结构public class SimpleHashMap<K, V> {private static final int DEFAULT_CAPACITY = 16;private static final float LOAD_FACTOR = 0.75f;private Entry<K, V>[] table;private int size;private static class Entry<K, V> {K key;V value;Entry<K, V> next;Entry(K key, V value, Entry<K, V> next) {this.key = key;this.value = value;this.next = next;}}@SuppressWarnings("unchecked")public SimpleHashMap() {table = new Entry[DEFAULT_CAPACITY];}public V put(K key, V value) {int hash = hash(key);int index = indexFor(hash, table.length);// 遍历链表for (Entry<K, V> e = table[index]; e != null; e = e.next) {if (e.key.equals(key)) {V oldValue = e.value;e.value = value;return oldValue;}}// 添加新节点addEntry(hash, key, value, index);return null;}private void addEntry(int hash, K key, V value, int index) {Entry<K, V> e = table[index];table[index] = new Entry<>(key, value, e);if (++size > table.length * LOAD_FACTOR) {resize(2 * table.length);}}private int hash(K key) {return key == null ? 0 : key.hashCode();}private int indexFor(int hash, int length) {return hash & (length - 1);}}
}

Q2: HashMap的扩容机制是怎样的?

public class HashMapResizeExample {public void demonstrateResize() {HashMap<String, Integer> map = new HashMap<>();// 1. 默认初始容量16,负载因子0.75System.out.println("初始容量:" + 16);System.out.println("扩容阈值:" + (16 * 0.75));// 2. 指定初始容量HashMap<String, Integer> customMap = new HashMap<>(32);// 3. 模拟扩容过程for (int i = 0; i < 13; i++) {map.put("key" + i, i);System.out.println("当前大小:" + map.size());}}// 扩容时的数据迁移public void demonstrateRehash() {HashMap<String, Integer> map = new HashMap<>(4);map.put("A", 1); // index = hash("A") & (4-1)map.put("B", 2);map.put("C", 3);// 扩容后 index = hash("A") & (8-1)}
}

TreeMap

Q3: TreeMap的实现原理是什么?

TreeMap基于红黑树实现,可以保证键的有序性。

public class TreeMapPrincipleExample {// 1. 自然排序public void naturalOrdering() {TreeMap<String, Integer> map = new TreeMap<>();map.put("C", 3);map.put("A", 1);map.put("B", 2);// 按键的自然顺序排序for (Map.Entry<String, Integer> entry : map.entrySet()) {System.out.println(entry.getKey() + ": " + entry.getValue());}}// 2. 自定义排序public void customOrdering() {TreeMap<Person, String> map = new TreeMap<>((p1, p2) -> {int ageCompare = Integer.compare(p1.getAge(), p2.getAge());if (ageCompare != 0) return ageCompare;return p1.getName().compareTo(p2.getName());});map.put(new Person("Tom", 20), "Student");map.put(new Person("Jerry", 18), "Student");map.put(new Person("Bob", 20), "Teacher");}// 3. 范围操作public void rangeOperations() {TreeMap<Integer, String> map = new TreeMap<>();for (int i = 1; i <= 10; i++) {map.put(i, "Value" + i);}// 获取子MapMap<Integer, String> subMap = map.subMap(3, 7);// 获取小于等于key的EntryMap.Entry<Integer, String> floorEntry = map.floorEntry(5);// 获取大于等于key的EntryMap.Entry<Integer, String> ceilingEntry = map.ceilingEntry(5);}
}

LinkedHashMap

Q4: LinkedHashMap的特点是什么?

LinkedHashMap在HashMap的基础上维护了一个双向链表,可以保持插入顺序或访问顺序。

public class LinkedHashMapExample {// 1. 插入顺序public void insertionOrder() {LinkedHashMap<String, Integer> map = new LinkedHashMap<>();map.put("A", 1);map.put("B", 2);map.put("C", 3);// 遍历时保持插入顺序}// 2. 访问顺序public void accessOrder() {LinkedHashMap<String, Integer> map = new LinkedHashMap<>(16, 0.75f, true);  // accessOrder = truemap.put("A", 1);map.put("B", 2);map.put("C", 3);map.get("A");  // 访问A,A会移到链表末尾// 遍历时A会在最后}// 3. LRU缓存实现public class LRUCache<K, V> extends LinkedHashMap<K, V> {private final int capacity;public LRUCache(int capacity) {super(capacity, 0.75f, true);this.capacity = capacity;}@Overrideprotected boolean removeEldestEntry(Map.Entry<K, V> eldest) {return size() > capacity;}}
}

ConcurrentHashMap

Q5: ConcurrentHashMap的实现原理是什么?

ConcurrentHashMap在Java 8中使用CAS和synchronized来保证并发安全。

public class ConcurrentHashMapExample {// 1. 基本使用public void basicUsage() {ConcurrentHashMap<String, Integer> map = new ConcurrentHashMap<>();map.put("A", 1);map.putIfAbsent("B", 2);map.computeIfAbsent("C", key -> 3);}// 2. 原子操作public void atomicOperations() {ConcurrentHashMap<String, AtomicInteger> map = new ConcurrentHashMap<>();map.putIfAbsent("counter", new AtomicInteger(0));// 线程安全的计数器map.get("counter").incrementAndGet();}// 3. 并发迭代public void concurrentIteration() {ConcurrentHashMap<String, Integer> map = new ConcurrentHashMap<>();// 填充数据for (int i = 0; i < 100; i++) {map.put("key" + i, i);}// 并发遍历map.forEach(8, (key, value) -> System.out.println(key + ": " + value));}
}

Q6: 如何选择合适的Map实现类?

public class MapSelectionExample {public void demonstrateUsage() {// 1. 一般用途,非线程安全Map<String, Object> hashMap = new HashMap<>();// 2. 需要有序Map<String, Object> treeMap = new TreeMap<>();// 3. 需要记住插入顺序Map<String, Object> linkedHashMap = new LinkedHashMap<>();// 4. 需要线程安全Map<String, Object> concurrentMap = new ConcurrentHashMap<>();// 5. 需要同步Map<String, Object> synchronizedMap = Collections.synchronizedMap(new HashMap<>());// 6. 实现LRU缓存Map<String, Object> lruCache = new LinkedHashMap<>(16, 0.75f, true) {@Overrideprotected boolean removeEldestEntry(Map.Entry eldest) {return size() > 100; // 限制大小为100}};}// 使用场景示例public void usageScenarios() {// 1. 频繁插入删除HashMap<String, Object> hashMap = new HashMap<>();// 2. 需要排序TreeMap<String, Object> treeMap = new TreeMap<>();// 3. 需要保持插入顺序LinkedHashMap<String, Object> linkedHashMap = new LinkedHashMap<>();// 4. 高并发场景ConcurrentHashMap<String, Object> concurrentMap = new ConcurrentHashMap<>();}
}

面试关键点

  1. 理解HashMap的底层实现
  2. 掌握HashMap的扩容机制
  3. 了解TreeMap的排序原理
  4. 熟悉LinkedHashMap的特点
  5. 理解ConcurrentHashMap的并发机制
  6. 掌握Map的选择原则
  7. 注意线程安全问题
  8. 理解性能和内存消耗
http://www.zhongyajixie.com/news/50345.html

相关文章:

  • 重庆电商平台网站建设长春网站建设团队
  • 当地自己的淘宝网站怎么做代运营竞价公司
  • wordpress首页显示当前时间优化网络的软件
  • 网站关键词如何优化营销型网站建设专家
  • 海口网站运营托管费用网站关键字排名优化
  • 郑州做网站公司有多少seoul什么意思
  • 西宁做网站最好的公司新媒体培训
  • 今天31个省新增最新消息视频讲解网站结构优化的内容和方法
  • 做三级分销商城网站设计b站推广链接
  • 在线生成电子印章抖音seo是什么意思
  • 盐田做网站的公司最近中国新闻热点大事件
  • 腾讯云点播做视频网站免费推广的方式有哪些
  • 东莞免费做网站公司网络营销方案怎么写
  • 绍兴cms建站模板seo平台怎么样
  • 网站推广的策略有哪些sem是什么的缩写
  • 网页画图工具如何优化关键词排名到首页
  • 大型企业网站建设网站推广的概念
  • 学习网站建设的书seo收费标准
  • 上海徐汇做网站火星时代教育培训机构学费多少
  • 新闻录入网站模板网站建设纯免费官网
  • 没有营业执照 怎么做网站行者seo
  • 做同城网站需要哪些域名seo站长工具
  • 国际加速器永久免费版北京seo的排名优化
  • 凯里网站建设公司百度指数峰值查询
  • 去掉wordpress页面的分类归档厦门seo优化外包公司
  • 网站建设属于什么服务企业推广策划书
  • 上海网站建设 浦东深圳百度代理
  • 网站建设的重点百度关键词搜索趋势
  • pyton 网站开发竞价培训课程
  • 网站建设开发语言seo建站的步骤